精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

"一致性相等"的陷阱

開發 后端
方法equals()與Comparable接口中的compareTo()方法是Java中最基本的兩個方法之一,然而它們的定義卻圍繞著"與相等一致"這一有趣的概念。

關于Object類中的equals()方法與Comparable接口中的compareTo()方法之間有何種關聯,之前還真沒考慮過。通過java.net看到此文之后,收獲了一點兒新知識,希望大家也能如此。

方法equals()與Comparable接口中的compareTo()方法是Java中最基本的兩個方法之一,然而它們的定義卻圍繞著"與相等一致"這一有趣的概念。

equals()方法

Java中的equals()方法既明確,又模糊。Java清楚地定義了如何準確地檢驗一個equals()方法是可用的。一個恰當的equals()方法必須是自反的,對稱的,可傳遞的,一致的,并能處理null引用。

然而equals()方法又是不清晰的。Javadoc說到,該方法指定了其它對象是"等于"這個對象的。注意,"等于"是放在引號中的。此處的關鍵就是,它沒有定義如何去判定這種相等性。

·對象的一致性(==)默認是繼承自Object類

·對象的整體可觀測的狀態,例如,若兩個對象是相等的,那么在應用的其它部分可以用一個對象去替代另一個對象。

·對象信息中的某些部分,如ID,使得檢驗對象相等性在邏輯上是有意義的。

compareTo()方法

Comparable接口定義了可比較性的概念。Javadoc指出compareTo()方法"強制設定了每個實現了該接口的類的對象的全部順序"。

實現了Comparable接口的類有一個天然的排序,這可便于存儲,也能在不使用單獨的Comparator的情況下,用于像TreeSet和TreeMap這樣的集合對象。

該接口的定義明晰,它要求其實現必須確保對稱性與傳遞性,就像equals()方法那樣。

一致性/非一致性相等

Comparable接口有如下描述

類C的天然排序意味著要與equals()方法保持一致,只有當且僅當e1.compareTo(e2) == 0與e1.equals(e2)有相同的布爾值。

基本上,這就要求由compareTo()定義的相等性與equals()方法定義的相等性具有相同的概念(除去有null的情況)。乍一看,該要求很簡單,但實際上它有其復雜性,后面將會討論到。

當考慮到操作符重載時,這種定義就特別有用。若我們假設有一種類Java語言,在這種語言中,==并不表示對象的同一性,而是通過方法去進行比較,大于/小于操作符也是如此,問題是調什么樣的方法。在類Java語言中大于/小于天然地就要基于compareTo()方法,而==則要調用equals()方法。

  1. // our new Java-like language  
  2. if (a < b) return "Less";      // translation ignoring nulls: if (a.compareTo(b) < 0)  
  3. if (a > b) return "Greater";   // translation ignoring nulls: if (a.compareTo(b) > 0)  
  4. if (a == b) return "Equal";    // translation ignoring nulls: if (a.equals(b))  
  5. throw new Exception("Impossible assuming no nulls?"); 

但如果compareTo()方法不是"一致性相等",那么上述代碼將會拋出異常,因為當a.equals(b)為false時,a.compareTo(b)會返回0。

在集合,如TreeMap,中還會發生其它問題:

  1. // Foo class is "inconsistent with equals"  
  2. assert foo1.equals(foo2) == false;  
  3. assert foo1.compareTo(foo2) == 0;  
  4.    
  5. TreeMap<Foo, String> map =   
  6. map.put(foo1, "a");  
  7. map.put(foo2, "b"); 

當使用equals()方法時,這兩個對象不相等,但使用compareTo()時,它們卻相等。在這種情況下,該Map的元素個數將為1,而非0。

由于這些"一致性相等"的問題,Javadoc說道"強烈建議(盡管并不要求)天然排序規則要與equals()方法保持一致"。

JDK中的許多類為了符合"一致性相等"這一規范而實現了Comparable接口。這些類包括Byte,Short,Integer,Long,Character和String。

還有些更有趣的類:

BigDecimal--肯定是"非一致性相等",比如4.00與4.0不一致,但進行比較時,認為它們是一樣的。

Double/Float--該類顯式地提供了排序規則,并為正零和負零,以及NaN都提供了相等性檢查,以確保它的compareTo()方法符合"一致性相等"。

CharSet--該類基于ID或名稱。equals()方法對待字段串是大小寫敏感的,但compareTo()方法卻不這樣。雖然名稱一般會符合某種標準,但這是一種值得懷疑的"一致性"。

*Buffer(nio)--該簇類的比較基于緩沖存放的內容,在我的測試中equals()和compareTo()是"一致的"。

Rdn(ldap)--該類的比較基于狀態的標準化格式,因此也是"一致性相等"。

ObjectStreamField(序列化)--該類的比較基于名稱,但會首先對基本數據類型進行排序。因為沒有覆蓋equals()方法,所以是"非一致性相等"。

 ...

注意:對于大多數的例子,我都不得不查看其源代碼或編寫測試程序以確定該類是不是符合"一致性相等"。這兒有一個不錯地清理Javadoc和檢驗UUID equals()方法的Adopt-a-JDK任務。

JSR-310

一直看到許多關于BigDecimal的問題,已有計劃將JSR-310中的類改造成"一致性相等",最近的一些帖子顯示這將造成多么大的爭議。

基本上,為某些類定義equals()和compareTo()看起來很容易。LocalDate表示某單一日歷系統中的某個日期,所以它有一個顯而易見的排序算法和相等規則。LocalTime則表示某個時刻,所以它也有一個明顯的排序算法和相等規則。Instant表示時間線上的某個時刻,那么它的排序與相等也是顯見的。

但在其它的情況下,這就不是那么顯而易見了。考慮這樣一個類OffsetDateTime:

  1. dt1 = OffsetDateTime.parse("2012-11-05T06:00+01:00");  
  2. dt2 = OffsetDateTime.parse("2012-11-05T07:00+02:00"); 

這樣的兩個日期-時刻對象代表時間線上一個相同的時刻點,但它們有不同的本地時,而且相對的UTC/格林威治時間的偏移量也不相同。

那么就有一個問題要留給讀者們...你更傾向于如下哪種觀點...

1. dt1不等于dt2,compareTo()分別比較本地時與偏移量,使用"一致性相等"(使用獨立的Comparator基于時刻對其進行排序)。

2. dt1不等于dt2,compareTo()基于時間線的上時刻點,使用"非一致性相等"。

3. dt1等于dt2,compareTo()基于時間線的上時刻點,使用"一致性相等"。

4. dt1等于dt2,且不實現Comparable接口。

5. dt1不等于dt2,且不實現Comparable接口。

我個人更傾向于讓dt1.equals(dt2)返回true這種方案,但我仍持開放態度。

順便地,也可以將這個問題提給BigDecimal,如果你能修改這個類,使其符合"一致性相等",你會修改它的equals()方法,還是compareTo()方法?

原文鏈接:http://www.blogjava.net/jiangshachina/archive/2012/12/06/392569.html

責任編輯:張偉 來源: blogjava
相關推薦

2017-07-25 14:38:56

數據庫一致性非鎖定讀一致性鎖定讀

2022-12-14 08:23:30

2025-09-08 07:25:16

2021-02-05 08:00:48

哈希算法?機器

2021-02-02 12:40:50

哈希算法數據

2021-07-26 06:33:42

CRDT數據CAP

2021-06-22 10:22:08

業務IT一致性首席信息官

2025-10-14 09:22:48

2020-05-12 10:43:22

Redis緩存數據庫

2020-11-24 09:03:41

一致性MySQLMVCC

2024-04-11 13:45:14

Redis數據庫緩存

2021-06-30 21:13:49

CPUCache數據

2022-03-22 09:54:22

Hash算法

2022-10-19 12:22:53

并發扣款一致性

2019-08-30 12:46:10

并發扣款查詢SQL

2020-04-01 15:50:17

TiDBMySQL數據庫

2020-08-05 08:46:10

NFS網絡文件系統

2021-02-04 06:30:26

Python編程語言

2025-03-27 08:20:54

2021-05-19 21:50:46

Hash算法測試
點贊
收藏

51CTO技術棧公眾號

欧美成人午夜激情在线| 欧美日韩1234| 日本欧洲国产一区二区| 中文字幕永久在线观看| 欧美不卡一区| 精品伊人久久97| 免费精品99久久国产综合精品应用| 制服丝袜中文字幕在线| 91亚洲精品久久久蜜桃| 国产精品综合网站| 国产污视频在线看| 成人婷婷网色偷偷亚洲男人的天堂| 日韩欧美中文字幕精品| 久久久久久久久久久久久久国产| 黄色网在线播放| 久久精品夜色噜噜亚洲aⅴ| 91免费看片在线| 激情综合网五月婷婷| 不卡一区综合视频| 国产视频精品va久久久久久| 激情在线观看视频| 性欧美hd调教| 亚洲福利视频一区| www.午夜色| 男人天堂网在线观看| 国产精品一区一区| 国产精品亚洲一区二区三区| 99热只有这里有精品| 欧美精品福利| 日韩中文字幕在线精品| 久久无码人妻精品一区二区三区 | 午夜av免费看| 国产精品国产亚洲精品| 精品视频色一区| 国产aaa一级片| 国产激情在线播放| 亚洲乱码国产乱码精品精的特点 | 欧美白人做受xxxx视频| 不卡视频在线看| av成人观看| 国产一区二区三区成人| 青草av.久久免费一区| 欧美一级电影久久| 中日韩精品视频在线观看| 午夜精品久久| 久久福利视频网| 永久免费看片视频教学| 久久婷婷蜜乳一本欲蜜臀| 中文字幕欧美精品日韩中文字幕| 国产网站无遮挡| 亚洲综合伊人| 91精品国产综合久久久久久漫画| 污片在线免费看| 国精品产品一区| 精品污污网站免费看| 黄色高清无遮挡| 亚洲精品一区| 在线精品视频小说1| 99免费视频观看| 成人精品动漫| 51午夜精品国产| 色哟哟在线观看视频| 日韩视频一区二区三区四区| 日韩丝袜美女视频| 性色av蜜臀av浪潮av老女人| 理论片一区二区在线| 日韩久久免费视频| 国产一区二区三区四区五区六区| 欧美系列电影免费观看| 综合136福利视频在线| 我要看黄色一级片| 欧美日本一区二区视频在线观看| 久久久久久久一区二区三区| 在线观看国产亚洲| 日韩电影在线免费看| 91九色国产视频| 亚洲免费一级片| 99精品久久只有精品| 欧美一区二区福利| 精品欧美色视频网站在线观看| 亚洲人成精品久久久久久| 国产女主播自拍| 中文字幕21页在线看| 欧美日韩一区在线| 美女又黄又免费的视频| 欧美理伦片在线播放| 在线日韩第一页| 玖玖爱这里只有精品| 一级成人国产| 国产精品爽爽爽| 亚洲欧美另类视频| 久久伊人中文字幕| 天堂v在线视频| 日韩伦理精品| 4438成人网| 午夜理伦三级做爰电影| 希岛爱理av一区二区三区| 性欧美视频videos6一9| 曰批又黄又爽免费视频| 岛国av在线一区| 亚洲激情电影在线| av中文字幕电影在线看| 欧美午夜片在线观看| 日本50路肥熟bbw| 青青草91久久久久久久久| 国内精品久久久久久| 久草热在线观看| 成人av网站在线观看免费| 色狠狠久久av五月综合| 69av成人| 欧美一级二级三级蜜桃| 51妺嘿嘿午夜福利| 亚洲免费精品| 91久久精品一区二区别| 国产一区电影| 精品久久久久久国产| 亚洲自拍第三页| 精品久久精品| 性色av一区二区咪爱| 国产福利第一视频| 国产精品无码永久免费888| 日本福利视频在线| 国产色99精品9i| 中文字幕亚洲在线| 色一情一乱一伦| www..com久久爱| 337p亚洲精品色噜噜狠狠p| 欧美日韩免费电影| 国产亚洲a∨片在线观看| 日韩 欧美 综合| 国产成人激情av| 一二三在线视频| 99久久久国产| 久久的精品视频| 国产精品人人妻人人爽| 欧美国产一区二区在线观看| 久久国产色av免费观看| 日韩成人一级| 欧美一级电影免费在线观看| 丝袜+亚洲+另类+欧美+变态| 午夜久久电影网| 在线免费播放av| 在线日韩欧美| 国产一区二区三区奇米久涩| 不卡的av影片| 亚洲精品在线观看网站| 久久久久久福利| 国产电影精品久久禁18| 欧美一区二区视频在线播放| 日韩精品视频在线看| 九九热最新视频//这里只有精品| 国产美女永久免费| 亚洲蜜桃精久久久久久久| 99999精品| 国产精品啊啊啊| 国产91aaa| av资源在线播放| 亚洲男人第一网站| 波多野结衣在线电影| 国产精品视频你懂的| 亚洲第一狼人区| 永久亚洲成a人片777777| 亚洲一区亚洲二区亚洲三区| 青青青草视频在线| 亚洲成人久久一区| 精品成人av一区二区在线播放| 91免费国产在线观看| 少妇高清精品毛片在线视频 | 风流少妇一区二区| 熟女少妇在线视频播放| 国产影视精品一区二区三区| 国产精品爽黄69| 七七成人影院| 亚洲欧美国产高清va在线播| 中文字幕观看在线| 亚洲欧美国产三级| 国产xxxxxxxxx| 蜜桃久久久久久| 国产乱子伦精品视频| 久久中文字幕导航| 国产精品久久久久久av| 国产激情在线视频| 日韩国产欧美精品在线 | 日本不卡免费在线视频| 91香蕉视频网址| 国产欧美三级电影| 国产精品久久久久久久久免费 | 亚洲国产你懂的| 中文字幕国产专区| 精品亚洲免费视频| 波多野结衣综合网| 99久久亚洲精品蜜臀| 国产视频一区二区三区四区| www.一区| 91精品国产网站| 久久综合之合合综合久久| 欧美精品一区二区三| 国产精品xxxxxx| 五月婷婷综合在线| 久久噜噜色综合一区二区| 成人少妇影院yyyy| 污视频网站观看| 亚洲激情亚洲| 国产卡一卡二在线| 国产精品美女久久久久久不卡| 亚洲一区二区少妇| 快播电影网址老女人久久| 欧美二区在线播放| av电影在线播放高清免费观看| 欧美精品一区二区三区蜜桃视频 | 欧美不卡视频一区| 欧美另类高清videos的特点| 精品人伦一区二区三区蜜桃网站 | www黄在线观看| 欧美精品一区二区三区视频 | 日韩精品中文字幕有码专区| 国产jzjzjz丝袜老师水多| 欧美亚洲一区二区在线观看| 国产91av视频| 一区二区三区在线播放| 欧美aaa级片| 91麻豆文化传媒在线观看| 国产乱国产乱老熟300部视频| 免费在线观看视频一区| 日韩人妻精品无码一区二区三区| 欧美日本三区| 日本a级片在线观看| 99热国内精品永久免费观看| 欧美日本韩国国产| 牛牛影视久久网| 国产激情美女久久久久久吹潮| 国产精品视频一区视频二区| 国产精自产拍久久久久久| 成人视屏在线观看| 日韩av电影手机在线| 欧亚av在线| 555www成人网| 麻豆理论在线观看| 97精品久久久| 国产v日韩v欧美v| 久久久欧美一区二区| 欧美xxxbbb| 久久久亚洲精选| jizz一区二区三区| 欧美激情一区二区久久久| 污污视频在线看| 欧美激情一级二级| а√天堂资源官网在线资源| 97视频免费在线观看| 嗯~啊~轻一点视频日本在线观看| 欧美夫妻性生活视频| 美足av综合网| 91极品女神在线| 国产精品av一区二区三区| 日产日韩在线亚洲欧美 | 亚洲自拍偷拍福利| 精品久久亚洲| 国产精品日韩高清| 偷窥自拍亚洲色图精选| 欧美日韩在线精品| 日韩视频在线观看| 国产精品av免费观看| 欧美日韩国产综合网| 国产乱子伦农村叉叉叉| 欧美一级视频| 中文字幕国产免费| 国产剧情一区在线| 国产毛片毛片毛片毛片毛片毛片| 91年精品国产| 99精品全国免费观看| 亚洲免费av在线| 日本三级理论片| 欧洲一区在线电影| 国产有码在线观看| 精品国产三级电影在线观看| 亚洲三区在线播放| 中文字幕亚洲字幕| 九色91在线| 日本精品久久久| 成人在线日韩| 久久久7777| 亚洲第一天堂| 人妻少妇被粗大爽9797pw| 美女视频黄免费的久久| 韩国黄色一级片| 久久久久久久国产精品影院| 日韩精品一区二区亚洲av性色| 亚洲一区电影777| 欧美日韩a v| 精品国产制服丝袜高跟| 欧美日韩影视| 久久91亚洲人成电影网站| 香蕉伊大人中文在线观看| 国产综合久久久久久| 狼人天天伊人久久| 黄频视频在线观看| 亚洲欧美日韩专区| 激情成人在线观看| 国产亚洲视频系列| 久久亚洲精品大全| 欧美视频精品在线| 性感美女视频一二三| 久久在线免费视频| 97久久香蕉国产线看观看| av一区二区三区免费| 欧美日韩有码| 337p粉嫩大胆噜噜噜鲁| 国模大尺度一区二区三区| 一级黄色片大全| 亚洲国产va精品久久久不卡综合| 在线观看黄色国产| 精品亚洲国产成av人片传媒| 午夜伦理在线视频| 91精品久久久久久久久青青 | 国产一区二区成人| 国产va在线视频| 国产66精品久久久久999小说| 五月激情久久久| 另类小说第一页| 久久久久久一级片| 日韩久久久久久久久| 日韩美女视频一区二区在线观看| 日日夜夜精品一区| 国产精品视频白浆免费视频| 国产精品羞羞答答在线观看| 欧美一级视频免费看| 粉嫩绯色av一区二区在线观看| 三级全黄做爰视频| 欧美私人免费视频| 国产私人尤物无码不卡| 9.1国产丝袜在线观看| 国产成人一二| 无码av天堂一区二区三区| 国产伦精品一区二区三区在线观看| 中文字幕91视频| 欧美日韩一卡二卡| avtt在线播放| 国产精品香蕉在线观看| 日韩精品电影| 亚洲美女性囗交| 国产精品久99| 国产精品久久久久久免费播放| 色多多国产成人永久免费网站| 99久久精品一区二区成人| 色乱码一区二区三在线看| 日本在线不卡视频| 国产亚洲精品久久久久久豆腐| 欧美日韩美女一区二区| 8888四色奇米在线观看| 国产精品香蕉av| 香港欧美日韩三级黄色一级电影网站| 91女神在线观看| 亚洲精品视频在线| www.黄色片| 性欧美亚洲xxxx乳在线观看| 日韩美女毛片| 黄色国产小视频| 国产精品乱码一区二三区小蝌蚪| 一区二区三区免费观看视频| 久久久极品av| 国产精品黄网站| 熟女性饥渴一区二区三区| 久久精品一级爱片| 91亚洲精品国偷拍自产在线观看| 久久综合久中文字幕青草| 97青娱国产盛宴精品视频| 亚洲 欧美 日韩 国产综合 在线| 91丨porny丨户外露出| 国产情侣小视频| 久久精品小视频| 国产一区二区三区亚洲| 99热成人精品热久久66| 国产精品国产三级国产有无不卡| 国产精品无码久久av| 久久久久久久久爱| 亚洲专区视频| 99精品视频国产| 精品国产91久久久久久老师| 岛国在线视频免费看| 亚洲mm色国产网站| 亚洲免费网站| 日本午夜在线观看| 日韩精品亚洲元码| 性欧美video另类hd尤物| 日本aa在线观看| 久久综合九色综合欧美98 | 免费高清在线一区| 日本特黄一级片| 中文字幕日韩电影| 超碰成人福利| 亚洲成人福利在线| 香蕉成人啪国产精品视频综合网 | 亚洲成a人片77777在线播放| 五月婷婷之婷婷| 天天色综合成人网| 麻豆视频在线免费观看| 另类欧美小说| 粉嫩久久99精品久久久久久夜| 在线观看免费中文字幕| 国内精品视频久久|