阿里巴巴Java開(kāi)發(fā)手冊(cè)——Comparator
問(wèn)題描述
上圖是《阿里巴巴Java開(kāi)發(fā)手冊(cè)v1.2.0》中的說(shuō)明,這里舉了個(gè)反例,說(shuō)沒(méi)有處理相等的情況,但我想:
o1.getId() > o2.getId()
反過(guò)來(lái)不就是
o1.getId() <= o2.getId()
我平時(shí)都是這樣用的,求大神在幫忙解釋一下這個(gè)地方的技巧是什么?是什么原因?
問(wèn)題解答
回答1:進(jìn)一步了解了一下,問(wèn)題的根本原因是JDK7的排序?qū)崿F(xiàn)改為了TimSort,詳細(xì)見(jiàn)這篇文章。http://blog.2baxb.me/archives...
一開(kāi)始回答的時(shí)候并沒(méi)有完全理解作者問(wèn)問(wèn)題的意圖,回答得有點(diǎn)草率,為此道個(gè)歉。分割線下是之前回答的內(nèi)容,因?yàn)榇鸢冈u(píng)論里有和@wanghaa 就舊有答案的討論,因此保留,也謝謝@wanghaa 讓我意識(shí)到問(wèn)題。
public static void main(String[] args) { int i = 1; int j = 1; int ret = i > j ? 1 : -1; System.out.println(ret);}
上面的代碼會(huì)輸出-1,進(jìn)行比較的兩個(gè)取值相等的情況下應(yīng)該返回0,返回-1肯定是不對(duì)的,所以一定要單獨(dú)處理相等的情況。
回答2:應(yīng)該要判斷等于0 的情況
回答3:經(jīng)過(guò)@gemoji的討論終于明白了,總結(jié)一下:在JDK7以前的版本就像Effective Java里說(shuō)的那樣,Comparator不強(qiáng)制要求實(shí)現(xiàn)等于,在JDK7之后的版本由于排序改用了TimSort算法,導(dǎo)致Comparator必須實(shí)現(xiàn)等于.


<<Effective Java中文版>>里面有詳細(xì)的解釋,其實(shí)這是一個(gè)強(qiáng)烈建議,反例這樣做其實(shí)破壞了equals和比較的傳遞性和對(duì)稱性
相關(guān)文章:
1. node.js - nodejs+express+vue2. python對(duì)8000行csv添加列3. javascript - 如何獲取未來(lái)元素的父元素在頁(yè)面中所有相同元素中是第幾個(gè)?4. javascript - onclick事件點(diǎn)擊不起作用5. python 字符串匹配問(wèn)題6. DADB.class.php文件的代碼怎么寫7. 使用mysql命令行連接遠(yuǎn)程數(shù)據(jù)庫(kù)host跳轉(zhuǎn)8. 數(shù)據(jù)庫(kù) - Mysql的存儲(chǔ)過(guò)程真的是個(gè)坑!求助下面的存儲(chǔ)過(guò)程哪里錯(cuò)啦,實(shí)在是找不到哪里的問(wèn)題了。9. javascript - 我的站點(diǎn)貌似被別人克隆了, google 搜索特定文章,除了域名不一樣,其他的都一樣,如何解決?10. python - 如何把152753這個(gè)字符串轉(zhuǎn)變成時(shí)間格式15:27:53

網(wǎng)公網(wǎng)安備