冒泡排序,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 慢多少,没想到是这样的结果,求大神告诉我是为啥