为啥我用 c 写的代码跑得比 Java (kotlin)慢

2018-06-08 14:40:04 +08:00
 bigtom

冒泡排序,OSX,跑得同一个数据集,10000 个随机 int 型数,kotlin 版的代码在 jvm 上跑用了 160ms,而 c 版的代码则跑了 300 毫秒。我写的 c 是不是有啥问题?

fun bubbleSort(arr: IntArray?) {
    if (arr == null || arr.isEmpty()) return
    var temp: Int

    for (i in 0 until arr.size) {
        for (j in arr.size - 1 downTo i + 1) {
            if (arr[j] < arr[j - 1]) {
                temp = arr[j]
                arr[j] = arr[j-1]
                arr[j-1] = temp
            }
        }
    }
}
void bubbleSort(int a[]) {
    int i,j,tmp;
    for (i = 0; i < SIZE; i++) {
        for (j = SIZE-1; j > i; j--) {
            if (a[j] < a[j-1]) {
                tmp = a[j];
                a[j] = a[j-1];
                a[j-1] = tmp;
            }
        }
    }
}

其实我原本只是想看看 jvm 处理这类问题的效率比 c 慢多少,没想到是这样的结果,求大神告诉我是为啥

2230 次点击
所在节点    问与答
14 条回复
ipwx
2018-06-08 14:44:54 +08:00
确认一下 int 是几字节
bigtom
2018-06-08 14:50:41 +08:00
@ipwx 四个字节
VDimos
2018-06-08 14:53:29 +08:00
数据会影响排序时间的,多测试几次,或者统一数据。另外,直接编译运行,别用 IDE 的运行功能来运行
rmb1222
2018-06-08 14:56:23 +08:00
开 -O3 了么
maxco292
2018-06-08 15:05:51 +08:00
编译选项贴一下,
测得时候多跑几次,如果测试时间出现差太多不能作为参考,有可能 JVM JIT 了,或者连续命中 cache。
可以对比一下 jvm 虚拟机代码与 C 代码汇编。
bigtom
2018-06-08 15:09:21 +08:00
@rmb1222 哇,瞬间变成 95ms。多谢大佬指点。
lance6716
2018-06-08 15:17:55 +08:00
@bigtom 所以其实大部分程序员对算法的优化并不如编译器的优化
bigtom
2018-06-08 15:26:46 +08:00
bigtom
2018-06-08 15:29:43 +08:00
@lance6716 部分同意,但是编译器可不能帮我把冒泡排序优化成快排。
sagaxu
2018-06-08 15:31:51 +08:00
jvm 要用 jmeter 测,否则 jit 有影响
tabris17
2018-06-08 15:32:06 +08:00
目测优化选项没开启
bumz
2018-06-08 15:36:39 +08:00
@lance6716 然而一般只对常数优化成立
jameslan
2018-06-09 04:32:13 +08:00
@rmb1222 有年头没用 c/c++了,想了解下,o3 现在算常规还是激进?
rmb1222
2018-06-09 10:35:14 +08:00
@jameslan o3 提升蛮有限的,还是 o2 用的比较多 0.0

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/461517

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX