Are Kotlin data types built off primitive or non-primitive Java data types?

I took an Int type and then tried to cast it as a Double by saying num as Double <…> However, this failed, saying that Int cannot be cast to Double. I am assuming this is because it is built off the Integer class rather than the raw int data type.

No, and there are two important points to note:

  • Kotlin positions its numeric types (Int, Long, Double etc.) as not being nested into each other, there is no subtyping relationship between these types. That’s why the cast intNum as Double does not succeed in Kotlin. That’s also why there’s no implicit conversions between these types. Instead, the numeric conversion is done with the corresponding functions (e.g. .toDouble())

  • The numeric type usages in Kotlin are compiled into JVM primitives where possible. Some usages require boxed types (e.g. a nullable Int? requires boxing, and so does a generic type implementation with an Int as a type argument), but the compiler decides whether they are necessary for each case.

<…> What is the most efficient way to cast values? There is a .toDouble() function, but this seems inefficient and unwieldy.

The most efficient way is to use the numeric conversion functions like .toDouble(). In fact, these functions are intrinsified, and there is no function call overhead when you use them. They are compiled closely to what javac would produce for a Java numeric cast or an implicit conversion. You can inspect the bytecode that the Kotlin compiler produces to find out what it’s under the hood and whether a specific conversion introduces any overhead.

See also: an answer to a similar question, (link)

Leave a Comment

tech