摘要:常用方法取的對(duì)象信息類的方法返回一個(gè)字符串,該字符串由類名對(duì)象是該類的一個(gè)實(shí)例標(biāo)記符和此對(duì)象哈希碼的無(wú)符號(hào)十六進(jìn)制表示組成。方法返回的運(yùn)行時(shí)類類型。至于同一個(gè)應(yīng)用程序在不同執(zhí)行期所得的調(diào)用結(jié)果,無(wú)需一致。
概念
object 類位于 java.lang 包中,是所有 Java 類的祖先,Java 中的每個(gè)類都由它擴(kuò)展而來(lái).
在定義一個(gè)類時(shí),如果沒(méi)有明確的繼承一個(gè)父類的話,那么它繼承的就是object類。
常用方法 取的對(duì)象信息:public String toString()Object 類的 toString 方法返回一個(gè)字符串,該字符串由類名(對(duì)象是該類的一個(gè)實(shí)例)、標(biāo)記符“@”和此對(duì)象哈希碼的無(wú)符號(hào)十六進(jìn)制表示組成。
該方法用得比較多,一般子類都有覆蓋。
public String toString(){ return getClass().getName() + "@" + Integer.toHexString(hashCOde()); }
getClass()方法返回Object的運(yùn)行時(shí)類類型。不可重寫,要調(diào)用的話,一般和getName()聯(lián)合使用,如getClass().getName();
示例
class Book{} class A{ public String toString(){ return "A類重載的toString"; } } public class testDemo { public static void main(String[] args) { Book b = new Book(); String s = "hello"; A a = new A(); System.out.println(b); System.out.println(b.toString()); System.out.println(s); System.out.println(a); } } 輸出結(jié)果: Book@15db9742 Book@15db9742 hello A類重載的toString
在進(jìn)行對(duì)象輸出的時(shí)候,輸出操作會(huì)自動(dòng)調(diào)用對(duì)象中的toString方法。Object類中的toString()方法為了適應(yīng)所有對(duì)象的輸出,所以只輸出了對(duì)象的編碼。
對(duì)象比較: public boolean equals(Object obj)Object中的equals方法是直接判斷this和obj本身的值是否相等,即用來(lái)判斷調(diào)用equals的對(duì)象和形參obj所引用的對(duì)象是否是同一對(duì)象.
public boolean equals(Object obj){ return (this == obj) }
該方法在開發(fā)中會(huì)經(jīng)常使用到,如果要進(jìn)行類的相等判斷,一般要進(jìn)行重寫。
示例:
class Book{ private String title; private double price; public Book(String title, double price){ this.title = title; this.price = price; } public String toString(){ return "書名:" + this.title + ",價(jià)格:" + this.price; } public boolean equals(Object obj){ if(this == obj){ return true; } if(obj == null){ return false; } if(!(obj instanceof Book)){ return false; } Book b = (Book) obj; if (this.title.equals(b.title) && this.price == b.price){ return true; }else{ return false; } } } public class testDemo { public static void main(String[] args) { Book b1 = new Book("java開發(fā)", 66.66); Book b2 = new Book("java開發(fā)", 66.66); Book b3 = new Book("java開發(fā)", 65.0); System.out.println(b1.equals(b2)); System.out.println(b1.equals(b3)); System.out.println(b1.equals("hello")); } } 輸出結(jié)果: true false false取的對(duì)象hash碼:public int hashCode()
按照一定的算法由對(duì)象得到的一個(gè)數(shù)值,散列碼沒(méi)有規(guī)律。
public native int hashCode();
hashCode() 方法主要用來(lái)在集合中實(shí)現(xiàn)快速查找等操作,也可以用于對(duì)象的比較。
在 Java 中,對(duì) hashCode 的規(guī)定如下:
在同一個(gè)應(yīng)用程序執(zhí)行期間,對(duì)同一個(gè)對(duì)象調(diào)用 hashCode(),必須返回相同的整數(shù)結(jié)果——前提是 equals() 所比較的信息都不曾被改動(dòng)過(guò)。至于同一個(gè)應(yīng)用程序在不同執(zhí)行期所得的調(diào)用結(jié)果,無(wú)需一致。
如果兩個(gè)對(duì)象被 equals() 方法視為相等,那么對(duì)這兩個(gè)對(duì)象調(diào)用 hashCode() 必須獲得相同的整數(shù)結(jié)果。
如果兩個(gè)對(duì)象被 equals() 方法視為不相等,那么對(duì)這兩個(gè)對(duì)象調(diào)用 hashCode() 不必產(chǎn)生不同的整數(shù)結(jié)果。
簡(jiǎn)單地說(shuō):如果兩個(gè)對(duì)象相同,那么它們的 hashCode 值一定要相同;如果兩個(gè)對(duì)象的 hashCode 值相同,它們并不一定相同。在 Java 規(guī)范里面規(guī)定,一般是覆寫 equals() 方法應(yīng)該連帶覆寫hashCode() 方法。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/73685.html
摘要:目錄介紹問(wèn)題匯總具體問(wèn)題好消息博客筆記大匯總年月到至今,包括基礎(chǔ)及深入知識(shí)點(diǎn),技術(shù)博客,學(xué)習(xí)筆記等等,還包括平時(shí)開發(fā)中遇到的匯總,當(dāng)然也在工作之余收集了大量的面試題,長(zhǎng)期更新維護(hù)并且修正,持續(xù)完善開源的文件是格式的同時(shí)也開源了生活博客,從年 目錄介紹 00.Java問(wèn)題匯總 01.具體問(wèn)題 好消息 博客筆記大匯總【16年3月到至今】,包括Java基礎(chǔ)及深入知識(shí)點(diǎn),Android技...
摘要:類似于中的事件驅(qū)動(dòng)函數(shù),當(dāng)有事件發(fā)生時(shí)候,通過(guò)回調(diào)函數(shù),通知主函數(shù)。一旦或內(nèi)的某個(gè)函數(shù)觸發(fā)了某個(gè)事件,就能通過(guò)監(jiān)聽接口發(fā)送給主函數(shù),類似中的事件回調(diào)函數(shù)。父類與子類通過(guò)實(shí)現(xiàn)接口調(diào)用,此時(shí)即為父類本身。 http://homeway.me/ 0x01.About 查了一些國(guó)內(nèi)資料,都說(shuō)java中extended與implements的區(qū)別是,一個(gè)類只能有一個(gè)繼承,一個(gè)類可...
摘要:一個(gè)對(duì)象內(nèi)存有多大為什么想知道這個(gè),自以為很重要,其實(shí)。參考鏈接對(duì)象解析不得不了解的對(duì)象頭從開始在位系統(tǒng)上會(huì)默認(rèn)開啟壓縮指針研究位引用指針壓縮技術(shù) java 一個(gè)對(duì)象內(nèi)存有多大 為什么想知道這個(gè),自以為很重要,其實(shí) just for fun =。= 測(cè)試相關(guān)說(shuō)明 jdk: java 官網(wǎng)上下載的,HotSpot 虛擬機(jī) java version 1.8.0_121 Java(TM)...
摘要:入坑指南是滴,下面是一個(gè)最低的入坑還應(yīng)該有種設(shè)計(jì)模式應(yīng)該掌握的。堆棧以幀為單位保存線程的狀態(tài),對(duì)堆棧的操作為壓棧和出棧執(zhí)行字節(jié)碼以后,將會(huì)產(chǎn)生程序計(jì)數(shù)器和棧,程序計(jì)數(shù)器存放將要執(zhí)行下一條指令的偏移量。 Java入坑指南是滴,下面是一個(gè)最低的入坑 還應(yīng)該有23種設(shè)計(jì)模式應(yīng)該掌握的。╮(╯▽╰)╭注意,第一個(gè)j是大寫。 Java的特點(diǎn)跨平臺(tái),風(fēng)格接近C++最重要的api文檔 https:/...
摘要:線程堆棧最擅長(zhǎng)與分析如下類型問(wèn)題系統(tǒng)無(wú)緣無(wú)故過(guò)高。性能瓶頸如無(wú)法充分利用等線程死鎖死循環(huán),餓死等。由于線程數(shù)量太多導(dǎo)致系統(tǒng)失敗如無(wú)法創(chuàng)建線程等。注意死鎖的兩個(gè)或多個(gè)線程是不消耗的,有的人認(rèn)為的使用率是線程死鎖導(dǎo)致的,這個(gè)說(shuō)法是完全錯(cuò)誤的。 不知覺間工作已有一年了,閑下來(lái)的時(shí)候總會(huì)思考下,作為一名Java程序員,不能一直停留在開發(fā)業(yè)務(wù)使用框架上面。老話說(shuō)得好,機(jī)會(huì)是留給有準(zhǔn)備的人的,因此...
閱讀 2649·2021-09-30 09:48
閱讀 2641·2019-08-30 14:10
閱讀 2796·2019-08-29 11:22
閱讀 1896·2019-08-26 13:51
閱讀 2342·2019-08-26 12:02
閱讀 2483·2019-08-23 16:06
閱讀 3625·2019-08-23 14:06
閱讀 1150·2019-08-23 13:56