DodgyCodeException
DodgyCodeException

Reputation: 6133

Safe cast vs cast to nullable

What is the difference between

x as? String

and

x as String?

They both seem to produce a String? type. The Kotlin page doesn't answer it for me.

UPDATE:

To clarify, my question is:

What is the purpose of having an as? operator at all, since for any object x and for any type T, the expression x as? T can be (I think) rephrased as x as T? ?

Upvotes: 33

Views: 18322

Answers (2)

Zoe - Save the data dump
Zoe - Save the data dump

Reputation: 28288

as? is the safe type cast operator. This means if casting fails, it returns null instead of throwing an exception. The docs also state the returned type is a nullable type, even if you cast it as a non-null type. Which means:

fun <T> safeCast(t: T){
    val res = t as? String //Type: String?
}

fun <T> unsafeCast(t: T){
    val res = t as String? //Type: String?
}

fun test(){
    safeCast(1234);//No exception, `res` is null
    unsafeCast(null);//No exception, `res` is null
    unsafeCast(1234);//throws a ClassCastException
}

The point of the safe cast operator is safe casting. In the above example, I used the original String example with integers as the type. unsafeCast on an Int of course throws an exception, because an Int is not a String. safeCast does not, but res ends up as null.

The main difference isn't the type, but how it handles the casting itself. variable as SomeClass? throws an exception on an incompatible type, where as variable as? SomeClass does not, and returns null instead.

Upvotes: 16

Kiskae
Kiskae

Reputation: 25603

The difference lies in when x is a different type:

val x: Int = 1

x as String? // Causes ClassCastException, cannot assign Int to String?

x as? String // Returns null, since x is not a String type.

Upvotes: 70

Related Questions