java.lang.IllegalArgumentException:比較方法違反了它的一般約定。
您的compare()方法 。如果A == B和B == C,則A必須等于C。
現在考慮這種情況:
對于A,B和C,假設containsKey()方法返回以下結果:
childMap.containsKey(A.getID()) 退貨 truechildMap.containsKey(B.getID()) 退貨 falsechildMap.containsKey(C.getID()) 退貨 true另外,考慮訂購A.getId()!= B.getId()。
所以,
A并B返回0,因為外部if條件為false=>A == BB并C返回0,因為外部if條件為false=>B == C但是,A和C可以根據塊內的測試返回-1或。因此,。這違反了傳遞原則。1``if``A != C
我認為,您應該在else塊內添加一些條件,該條件類似于塊內的執行檢查if。
解決方法您好,以下是我的比較器的比較方法。我不確定是什么問題。我在堆棧溢出時查找了其他類似標題的問題和答案,但不確定我的方法有什么問題,但我一直在獲取java.lang.IllegalArgumentException:比較方法違反了它的一般約定!
任何幫助將不勝感激
public int compare(Node o1,Node o2){ HashMap<Integer,Integer> childMap = orderMap.get(parentID); if(childMap != null && childMap.containsKey(o1.getID()) && childMap.containsKey(o2.getID())) {int order1 = childMap.get(o1.getID());int order2 = childMap.get(o2.getID());if(order1<order2) return -1;else if(order1>order2) return 1;else return 0; } elsereturn 0;}
添加我得到的異常
java.lang.IllegalArgumentException: Comparison method violates its general contract!at java.util.TimSort.mergeLo(TimSort.java:747)at java.util.TimSort.mergeAt(TimSort.java:483)at java.util.TimSort.mergeCollapse(TimSort.java:410)at java.util.TimSort.sort(TimSort.java:214)at java.util.TimSort.sort(TimSort.java:173)at java.util.Arrays.sort(Arrays.java:659)at java.util.Collections.sort(Collections.java:217)
相關文章:
1. 關于docker下的nginx壓力測試2. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題3. mac里的docker如何命令行開啟呢?4. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””5. docker容器呢SSH為什么連不通呢?6. nignx - docker內nginx 80端口被占用7. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?8. docker-compose 為何找不到配置文件?9. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????10. angular.js使用$resource服務把數據存入mongodb的問題。

網公網安備