Java?Object類和包裝類深入解讀
查看源代碼方法
在IDEA中雙擊 shift 鍵,可以搜索相關(guān)類名,查看源代碼
點(diǎn)擊Structure ,左側(cè)用橙色床框住的部分是類的結(jié)構(gòu),結(jié)構(gòu)包含所有的方法、屬性、內(nèi)部類的聲明。結(jié)構(gòu)中帶綠色小鎖的圖標(biāo)表示 public 權(quán)限,鑰匙圖標(biāo)就是繼承權(quán)限(protected),紅色鎖的圖標(biāo)就是 private 權(quán)限。右邊是源碼。
Object類
定義及應(yīng)用
Object類是所有類的默認(rèn)父類,不需要使用 extends 顯示繼承,因此 Object 類的所有方法(private 除外),所有類的對象都能使用。因此所有對象都可以通過Object來接收
示例:
Object obj1 = "test"; Object obj2 = new Student("小陳",18); Object obj3 = 123;
在Java中對Object類做了擴(kuò)充,使它不僅是所有類的父類,只要是引用數(shù)據(jù)類型,都可以向上轉(zhuǎn)型為Object類,包括數(shù)組和接口也就是說, Object 類是引用數(shù)據(jù)類型的最高參數(shù)統(tǒng)一化
接下來我們來了解Object類中兩個常用的方法
1. toString()
將任意對象轉(zhuǎn)為字符串輸出,打印對象內(nèi)容。System.out.println()接收任意對象并輸出,就是默認(rèn)調(diào)用的 toString方法
運(yùn)行下面代碼:
class Student{ private String name; private int age; public Student(String name,int age){ this.name = name; this.age = age; } } public class ObjectTest { public static void main(String[] args) { Student s1 = new Student("張三",17); System.out.println(s1); } }
運(yùn)行結(jié)果:
可以看到不是我們預(yù)期的結(jié)果,為什么呢?我們來看看 toString() 的源碼
此時想要輸出具體內(nèi)容,就需要覆寫 toString()方法:
public String toString() { return "Student{" + "name='" + name + '\'' + ", age=" + age + '}'; }
//輸出:Student{name='張三', age=17}
2. equals( )
比較兩個對象是否相等,通常比較屬性,承接上例,我們創(chuàng)建一個新對象和s1比較:
Student s1 = new Student("張三",17); Student s2 = new Student("張三",17); System.out.println(s1.equals(s2));
//輸出:false
s1和s2的名字和年齡都是相同的,為什么輸出結(jié)果為false呢?讓我們來看看equals方法的源碼
有 new 就有新對象,所以s1和s2顯然不是同一地址。此時Student類默認(rèn)使用的是Object類提供的equals方法,對于Object類而言,它不知道子類有哪些屬性 ,所以比較的是對象的地址。
如果我們想要比較屬性值就要覆寫equals方法:
public boolean equals(Object obj){ //當(dāng)前對象和傳入的obj比較 //1.判斷 obj 是否為空 if (obj == null){ return false; } //2.判斷obj是否就是自己,就是地址相同 if (obj == this){ return true; } //3.判斷obj是否是該類的對象,比如傳入一個字符串,它不是Student類型,無法比 if (!(obj instanceof Object) ){ return false; } //4.此時obj一定是Student類的對象,而且兩個對象不是同一個地址 //向下轉(zhuǎn)型還原為Student,比較對象屬性 Student stu = (Student) obj; return this.name.equals(stu.name)&& this.age == stu.age; } }
equals方法的覆寫非常重要?。?!一定要掌握,代碼中應(yīng)用到的 instanceof 和 向下轉(zhuǎn)型的知識鏈接如下,感興趣的可以去看看哦
包裝類
定義及應(yīng)用
包裝類就是將8種數(shù)據(jù)類型封裝為類:
對象包裝類(Object雷的直接子類) | Boolean、Character |
數(shù)值型包裝類(Number類的直接子類) | Byte、Short、Integer、Long、Float、Double |
以 Integer 類為例應(yīng)用:
public static void main(String[] args) { //將int -> 類 Integer data = new Integer(10); //value就是將包裝類的內(nèi)容取出來 int a = data.intValue(); System.out.println(a); }
//輸出:10
裝箱和拆箱
裝箱:將基本類型變?yōu)榘b類對象
拆箱:將包裝類對象中的數(shù)值還原為基本類型
在上述示例中:
在我們實(shí)際操作時,反復(fù)的拆裝箱是很麻煩的,在Java中為我們提供了自動裝箱、拆箱
代碼示例:
public static void main(String[] args) { Integer a = 20; int b = a+2; System.out.println(b); }
//輸出:22
可以看到,a是Integer類的對象,但它可以直接和整型數(shù)據(jù)做運(yùn)算,實(shí)際上, Integer a = 20;就是自動裝箱, int b = a+2;就是自動拆箱過程。所以在用法上,包裝類和基本類型沒有區(qū)別。但是一定要記住,基本數(shù)據(jù)類型的默認(rèn)值是0,包裝類的默認(rèn)值為null
那么我們什么時候使用包裝類,什么時候使用基本數(shù)據(jù)類型呢?阿里編碼規(guī)約做如下規(guī)定:
- 在類中定義成員變量,必須使用包裝類聲明
- 在方法中,大量進(jìn)行算術(shù)運(yùn)算使用基本類型
自己實(shí)現(xiàn)包裝類
public class IntDemo { //保存具體的整型值 private int data; public IntDemo(int data){ this.data = data; } public int intValue(){ return this.data; } public static void main(String[] args) { //將int -> 類 IntDemo demo = new IntDemo(10); int data = demo.intValue(); System.out.println(data+1); } }
//輸出結(jié)果:11
通過包裝類讓Object類接收基本數(shù)據(jù)類型
我們已經(jīng)知道Object類可以接收所有引用類型,可遇到基本數(shù)據(jù)類型就行不通了,包裝類就完美解決了這一問題。
使用Object類接收,將上例的主方法做如下修改:
public static void main(String[] args) { //將int -> 類 IntDemo demo = new IntDemo(10); Object obj = demo; IntDemo demo1 = (IntDemo) obj; int data = demo1.intValue(); System.out.println(data+1); }
//輸出:11
包裝類的對象比較
統(tǒng)一使用 equals 方法
Integer a = 10; Integer b =10; System.out.println(a .equals(b) );
//輸出:true
包裝類和String的相互轉(zhuǎn)換
① 包裝類 --> String :使用String.valueOf()
② String --> 包裝類 :使用包裝類的parse***()
代碼實(shí)現(xiàn):
public static void main(String[] args) { //Integer -> String Integer x = new Integer(200); String y = String.valueOf(x); System.out.println(y); //String-> Integer String str ="123"; Integer a = Integer.parseInt(str); System.out.println(a); }
//輸出結(jié)果:
200
123
注意String轉(zhuǎn)換時若字符串不是純數(shù)字組成,運(yùn)行時就是出現(xiàn)類型轉(zhuǎn)換異常。
到此這篇關(guān)于Java Object類和包裝類深入解讀的文章就介紹到這了,更多相關(guān)Java Object類內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot 二維碼生成base64并上傳OSS的實(shí)現(xiàn)示例
本文主要介紹了SpringBoot 二維碼生成base64并上傳OSS的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05mybatis配置mapper-locations位置的三種方式小結(jié)
這篇文章主要給大家介紹了關(guān)于mybatis配置mapper-locations位置的三種方式,Mybatis-Plus的初衷是為了簡化開發(fā),而不建議開發(fā)者自己寫SQL語句的,但是有時客戶需求比較復(fù)雜,需要的朋友可以參考下2023-08-08Java實(shí)現(xiàn)SSL雙向認(rèn)證的方法
這篇文章主要介紹了Java實(shí)現(xiàn)SSL雙向認(rèn)證的方法,實(shí)例分析了ssl認(rèn)證的原理與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-08-08mybatis plus條件構(gòu)造器queryWrapper、updateWrapper
這篇文章主要介紹了mybatis plus條件構(gòu)造器queryWrapper、updateWrapper,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09java HashMap內(nèi)部實(shí)現(xiàn)原理詳解
這篇文章主要介紹了java HashMap內(nèi)部實(shí)現(xiàn)原理詳解的相關(guān)資料,需要的朋友可以參考下2017-02-02SpringCloud將Nacos作為配置中心實(shí)現(xiàn)流程詳解
這篇文章主要介紹了Springcloud中的Nacos Config服務(wù)配置,本文以用戶微服務(wù)為例,進(jìn)行統(tǒng)一的配置,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10