java通用对象_有效的Java –所有对象通用的方法
java通用對象
所有對象共有的方法(第3章)
這是Joshua Blochs的有效Java第3章的簡短摘要。我僅包含與自己相關的項目。
一般
等值合約將等價關系描述為:
- x.equals(null) == false
- 自反 – x.equals(x) == true
- 對稱 –如果x.equals(y) == true則y.equals(x) == true
- 傳遞性 –如果x.equals(y) == true和y.equals(z) == true則x.equals(z) == true
- 一致 –在相同的未修改對象上多次調用equals,返回相同的值。
有一些值得注意的屬性可以改變:
- 如果違反了以上約定,則其他對象(如List.contains() )的行為未定義。
- 除非您愿意放棄OO抽象的優點,否則無法在保留等值關系的同時用新的值字段/組件擴展可實例化的類。
- 注意,如果基類是抽象的,就可以了。
- java.net.URL依賴于與URL關聯的主機的IP地址,這些主機需要網絡訪問,因此會破壞一致性。
- 這本書給出了創建最佳等式的方法:
- 檢查參數==this
- 使用的instance of檢查類型是否正確
- 轉換為正確的類型
- 比較重要領域
當您覆蓋
哈希碼由基于哈希的結構使用。 哈希碼協定中最重要的部分規定,相等的對象必須返回相等的哈希碼。 此外,哈希碼函數應為不相等的對象返回不同的值,以提高性能。 如果沒有正確的哈希碼實現,則將相等的對象視為不相等的基于哈希的結構將表現不佳,甚至更糟。 如果將常量值作為hashCode提供,例如... return 42 ,則哈希表會退化為鏈接列表,并且程序應以線性時間運行,并以二次時間運行。
始終覆蓋
…因為它使調試容易得多。
注意
實現Clonable使Object.clone()返回一個逐字段的副本,否則將拋出CloneNotSupportedException 。 通常,克隆會創建一個對象,但會繞過構造函數。 實現clone存在幾個挑戰:
- 通常,尤其是在擴展類時,在覆蓋clone ,應返回super.clone()返回的對象以獲取正確的類型。 這不是強制性的,它由用戶決定,但是如果沒有它,克隆可能會中斷。
- clone不會復制可變的對象字段,因此super.clone()將引用相同的對象字段。 必須手動克隆字段。
- 從本質上講,這意味著與克隆一起使用時,字段不能為“ final”,除非可以共享相同的字段值。
- 由于clone在不使用構造函數的情況下創建對象,因此必須確保創建后所有不變式都是正確的。
- 必須在內部列表/數組上遞歸調用clone 。
一般建議是避免使用和實現Object.clone() ,而是使用復制構造函數public Yum(Yum yum)或工廠,除非復制數組。
實施
可比較處理訂單比較,例如在使用TreeSet , TreeMap , search或sort 。
- 可比對象具有相似的合同,即equals ,如果被破壞,可能會導致行為不穩定。 合同要求對稱,自反和傳遞。
- equals是不符合compareTo可以創建一些集合重復。
- Float和Double具有它們自己的靜態compareTo方法,這些方法應簡化處理浮點問題。
- 減去整數以創建compareTo返回值時要小心,因為它可能會導致溢出(即在Integer.MAX_VALUE之外)并創建錯誤的返回值! 如果i為大正值而j為大負值,則ij將溢出并返回負值。
翻譯自: https://www.javacodegeeks.com/2017/05/effective-java-method-common-objects.html
java通用對象
總結
以上是生活随笔為你收集整理的java通用对象_有效的Java –所有对象通用的方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 峡组词 峡字如何组词
- 下一篇: 琥珀ai_琥珀项目:Java的未来暴露