补注: 近来又看 go 的排序, 发现以前对 go 的排序理解的有点浅了. go 的排序思路和 c 和 c++ 有些差别. c 默认是对数组进行排序, c++ 是对一个序列进行排序, go 则更宽泛一些,待排序的可以是任何对象, 虽然很多情况下是一个 slice (分片, 类似于数组),或是包含 slice 的一个对象. 排序(接口)的三个要素: 待排序元素个数 n : 第 i 和第 j 个元素的比较函数 cmp : 第 i 和 第 j 个元素的交换 swap : 乍一看条件 3 是多余的, c