Kotlin VS Java benchmarks

Current benchmark data was generated on Mon Jun 23 2025, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][4 cores] AMD EPYC 7763 64-Core Processor (Model 1)

* -m in a file name stands for multi-threading or multi-processing

* -i in a file name stands for direct intrinsics usage. (Usage of simd intrinsics via libraries is not counted)

* -ffi in a file name stands for non-stdlib FFI usage

* (You may find time < time(user) + time(sys) for some non-parallelized programs, the overhead is from GC or JIT compiler, which are allowed to take advantage of multi-cores as that's more close to real-world scenarios.)

binarytrees

Input: 18

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 2.java 460ms 10ms 573.4MB 563ms 83ms openjdk 21
java 2-m.java 468ms 7.1ms 643.1MB 657ms 120ms graal/jvm 17.0.8
java 2.java 476ms 4.7ms 636.3MB 577ms 107ms openjdk 23
kotlin 1.kt 502ms 3.0ms 581.8MB 603ms 93ms kotlin/jvm 21
java 2.java 1176ms 4.0ms 1040.7MB 573ms 763ms openjdk/zgc 21
kotlin 1.kt 4205ms 55ms 144.8MB 4410ms 63ms kotlin/native 2.1.20

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 121ms 3.5ms 163.1MB 150ms 30ms kotlin/jvm 21
java 2-m.java 124ms 0.8ms 96.2MB 163ms 30ms openjdk 23
java 2.java 125ms 2.0ms 167.1MB 157ms 30ms openjdk 21
java 2-m.java 147ms 1.3ms 215.1MB 227ms 50ms graal/jvm 17.0.8
kotlin 1.kt 219ms 14ms 17.7MB 223ms 7ms kotlin/native 2.1.20
java 2.java 313ms 2.8ms 241.6MB 160ms 207ms openjdk/zgc 21

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2-m.kt 1914ms 60ms 234.2MB 7147ms 110ms kotlin/jvm 21
java 1-m.java 2071ms 296ms 257.7MB 7843ms 130ms openjdk 21
kotlin 1.kt 2192ms 8.0ms 218.7MB 3023ms 70ms kotlin/jvm 21
java 1-m.java 2461ms 69ms 243.6MB 9343ms 137ms openjdk 23
java 1-m.java 3046ms 337ms 1240.3MB 9980ms 1080ms openjdk/zgc 21
kotlin 2-m.kt 4300ms 30ms 21.1MB 14380ms 537ms kotlin/native 2.1.20
kotlin 1.kt timeout 0.0ms 17.4MB 5517ms 30ms kotlin/native 2.1.20

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2-m.kt 249ms 2.2ms 21.4MB 840ms 40ms kotlin/native 2.1.20
kotlin 1.kt 389ms 6.7ms 17.4MB 397ms 7ms kotlin/native 2.1.20
java 1-m.java 436ms 14ms 92.6MB 1433ms 47ms openjdk 23
java 1-m.java 470ms 21ms 119.1MB 1560ms 67ms openjdk 21
kotlin 1-m.kt 482ms 16ms 75.4MB 1090ms 40ms kotlin/jvm 21
java 1-m.java 648ms 7.9ms 215.5MB 1700ms 267ms openjdk/zgc 21
kotlin 2-m.kt 814ms 72ms 95.6MB 2813ms 77ms kotlin/jvm 21

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 2.1ms 0.1ms 3.0MB 0ms 0ms kotlin/native 2.1.20
kotlin 1-m.kt 62ms 0.8ms 47.8MB 78ms 18ms kotlin/jvm 21
java 1.java 64ms 2.4ms 52.4MB 66ms 18ms graal/jvm 17.0.8
java 1.java 72ms 4.4ms 44.7MB 78ms 16ms openjdk 23
java 1.java 73ms 4.9ms 43.8MB 76ms 20ms openjdk 21
java 1.java 192ms 4.4ms 42.8MB 80ms 136ms openjdk/zgc 21

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2-m.kt 4779ms 156ms 415.1MB 14780ms 2513ms kotlin/jvm 21
kotlin 1.kt timeout 0.0ms 397.0MB 16267ms 2767ms kotlin/jvm 21

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 2041ms 202ms 241.1MB 5747ms 710ms kotlin/jvm 21
kotlin 2-m.kt 2177ms 125ms 242.9MB 5933ms 677ms kotlin/jvm 21

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 766ms 91ms 171.9MB 2060ms 83ms kotlin/jvm 21

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 1844ms 20ms 667.3MB 4333ms 157ms kotlin/jvm 21

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2.kt 166ms 1.9ms 12.4MB 167ms 0ms kotlin/native 2.1.20
kotlin 1-m.kt 197ms 7.4ms 94.7MB 323ms 30ms kotlin/jvm 21
kotlin 2-m.kt 201ms 1.6ms 102.7MB 457ms 37ms kotlin/jvm 21
kotlin 1.kt 375ms 17ms 12.4MB 380ms 0ms kotlin/native 2.1.20

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2-m.kt 317ms 2.5ms 210.7MB 540ms 50ms kotlin/jvm 21
kotlin 1.kt 341ms 2.0ms 203.0MB 457ms 40ms kotlin/jvm 21
kotlin 2.kt 475ms 2.5ms 12.5MB 503ms 0ms kotlin/native 2.1.20
kotlin 1.kt 1046ms 1.8ms 12.5MB 1073ms 3ms kotlin/native 2.1.20

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 2.kt 95ms 0.1ms 12.8MB 87ms 0ms kotlin/native 2.1.20
kotlin 1.kt 122ms 1.1ms 12.8MB 117ms 0ms kotlin/native 2.1.20
kotlin 1-m.kt 153ms 4.0ms 92.4MB 293ms 27ms kotlin/jvm 21
kotlin 2-m.kt 170ms 16ms 95.9MB 367ms 37ms kotlin/jvm 21

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 394ms 11ms 680.4MB 447ms 93ms kotlin/jvm 21
java 1.java 399ms 2.4ms 541.9MB 497ms 87ms openjdk 23
java 1.java 408ms 5.6ms 680.1MB 483ms 90ms openjdk 21
java 1-m.java 440ms 67ms 657.5MB 653ms 120ms graal/jvm 17.0.8
java 1.java 1057ms 29ms 961.6MB 450ms 737ms openjdk/zgc 21
kotlin 1.kt 1937ms 26ms 90.4MB 2023ms 40ms kotlin/native 2.1.20

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 159ms 3.2ms 207.4MB 210ms 43ms kotlin/jvm 21
java 1-m.java 162ms 3.2ms 158.1MB 240ms 33ms openjdk 23
java 1-m.java 165ms 0.9ms 206.3MB 233ms 43ms openjdk 21
java 1-m.java 213ms 5.0ms 253.5MB 343ms 70ms graal/jvm 17.0.8
kotlin 1.kt 288ms 11ms 25.8MB 290ms 10ms kotlin/native 2.1.20
java 1.java 415ms 9.6ms 341.9MB 217ms 273ms openjdk/zgc 21

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1n.kt 354ms 2.9ms 3.6MB 343ms 0ms kotlin/native 2.1.20
java 1.java 441ms 5.0ms 45.2MB 473ms 17ms openjdk 21
kotlin 1.kt 444ms 1.3ms 49.7MB 487ms 20ms kotlin/jvm 21
java 1.java 449ms 1.1ms 47.9MB 480ms 20ms openjdk 23
java 1.java 450ms 4.6ms 81.4MB 480ms 23ms graal/jvm 17.0.8
java 1.java 573ms 3.6ms 44.8MB 497ms 140ms openjdk/zgc 21
java 2.java 1253ms 11ms 668.0MB 1373ms 93ms openjdk 21
java 2.java 1255ms 4.2ms 766.6MB 1373ms 100ms openjdk 23
java 2.java 3285ms 47ms 2400.8MB 1683ms 1837ms openjdk/zgc 21

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1n.kt 40ms 1.0ms 3.5MB 30ms 0ms kotlin/native 2.1.20
java 1.java 118ms 2.7ms 81.6MB 150ms 27ms graal/jvm 17.0.8
kotlin 1-m.kt 121ms 1.7ms 49.7MB 167ms 17ms kotlin/jvm 21
java 1.java 124ms 1.2ms 48.5MB 157ms 23ms openjdk 23
java 1.java 135ms 27ms 45.4MB 153ms 13ms openjdk 21
java 1.java 249ms 2.6ms 44.8MB 167ms 143ms openjdk/zgc 21
java 2-m.java 295ms 10ms 352.2MB 433ms 50ms openjdk 21
java 2-m.java 313ms 6.2ms 395.9MB 450ms 63ms openjdk 23
java 2.java 705ms 8.5ms 535.8MB 483ms 417ms openjdk/zgc 21

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 3227ms 47ms 445.3MB 3660ms 107ms graal/jvm 17.0.8
java 1.java 3739ms 47ms 425.9MB 4580ms 113ms openjdk 21
java 1.java 3759ms 36ms 413.3MB 4657ms 123ms openjdk 23
kotlin 1.kt 3774ms 15ms 353.5MB 4633ms 110ms kotlin/jvm 21
java 1.java timeout 0.0ms 1935.2MB 4677ms 1170ms openjdk/zgc 21
kotlin 1n.kt timeout 0.0ms 26.6MB 4053ms 1487ms kotlin/native 2.1.20
kotlin 2n.kt timeout 0.0ms 30.6MB 5113ms 140ms kotlin/native 2.1.20

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 1.java 900ms 18ms 443.2MB 1240ms 93ms graal/jvm 17.0.8
java 1-m.java 983ms 6.0ms 389.1MB 1830ms 93ms openjdk 21
java 1-m.java 1002ms 11ms 420.7MB 1840ms 107ms openjdk 23
kotlin 1-m.kt 1024ms 7.6ms 352.8MB 1743ms 87ms kotlin/jvm 21
java 1.java 2053ms 7.5ms 1352.6MB 1690ms 1090ms openjdk/zgc 21
kotlin 1n.kt timeout 0.0ms 26.9MB 4010ms 1517ms kotlin/native 2.1.20
kotlin 2n.kt timeout 0.0ms 30.7MB 5123ms 140ms kotlin/native 2.1.20

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 3.java timeout 0.0ms 407.0MB 5410ms 93ms graal/jvm 17.0.8
java 3.java timeout 0.0ms 301.8MB 5317ms 57ms openjdk 21
java 3.java timeout 0.0ms 304.7MB 5323ms 63ms openjdk 23
java 3.java timeout 0.0ms 468.6MB 4977ms 290ms openjdk/zgc 21
kotlin 1.kt timeout 0.0ms 173.5MB 5417ms 50ms kotlin/jvm 21
kotlin 1n.kt timeout 0.0ms 226.8MB 5067ms 120ms kotlin/native 2.1.20

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
java 3-m.java 783ms 10ms 177.2MB 1163ms 57ms graal/jvm 17.0.8
java 3-m.java 799ms 9.6ms 128.8MB 1183ms 30ms openjdk 21
java 3-m.java 810ms 6.7ms 136.5MB 1217ms 37ms openjdk 23
kotlin 1-m.kt 828ms 9.1ms 134.4MB 1267ms 40ms kotlin/jvm 21
java 3.java 979ms 21ms 132.9MB 1173ms 183ms openjdk/zgc 21
kotlin 1n.kt 3234ms 34ms 51.1MB 3313ms 80ms kotlin/native 2.1.20

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1.kt 3088ms 35ms 232.4MB 4080ms 73ms kotlin/jvm 21

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
kotlin 1-m.kt 982ms 20ms 231.5MB 1887ms 53ms kotlin/jvm 21