data:image/s3,"s3://crabby-images/0483c/0483c99595853f2ba173285f545f2f789f720a2a" alt="Kotlin ranges"
data:image/s3,"s3://crabby-images/43ff9/43ff94cd475684799296cb23c953b69da82ce240" alt="kotlin ranges kotlin ranges"
data:image/s3,"s3://crabby-images/43690/4369006702cb318aa400bd266bac74649d98c8a4" alt="kotlin ranges kotlin ranges"
The same compilation behavior is seen for simple decrementing progressions as well (e.g.
data:image/s3,"s3://crabby-images/ed68d/ed68db909dec36facd908c29be54562b589c6984" alt="kotlin ranges kotlin ranges"
It allocates a couple primitives and has a couple if-checks, but is otherwise fairly simple. Given that the compiler can optimize ranges, which of the following range-based for-loops do you think is the most efficient? // Option 1 No allocations necessary! Range Against The Machine In other words, when endInclusive urlThumbĪgain, the above compiles to a series of simple conditionals. That's because IntRange is defined by its minimum start and its maximum endInclusive values. If you think the answer is 123321, guess again. Pop quiz: What does the following code output? (1.3).forEach(System.out::print) Here are a few interesting aspects of Kotlin ranges, some of which I've found to be less-than-intuitive.
data:image/s3,"s3://crabby-images/0483c/0483c99595853f2ba173285f545f2f789f720a2a" alt="Kotlin ranges"