Java中instanceof關(guān)鍵字的理解

java 中的instanceof 運(yùn)算符是用來在運(yùn)行時(shí)指出對(duì)象是否是特定類的一個(gè)實(shí)例。instanceof通過返回一個(gè)布爾值來指出,這個(gè)對(duì)象是否是這個(gè)特定類或者是它的子類的一個(gè)實(shí)例。

用法:?

result = object instanceof class?

參數(shù):?

Result:布爾類型。?

Object:必選項(xiàng)。任意對(duì)象表達(dá)式。?

Class:必選項(xiàng)。任意已定義的對(duì)象類。?

說明:?

如果 object 是 class 的一個(gè)實(shí)例,則 instanceof 運(yùn)算符返回 true。如果 object 不是指定類的一個(gè)實(shí)例,或者 object 是 null,則返回 false。

但是instanceof在Java的編譯狀態(tài)和運(yùn)行狀態(tài)是有區(qū)別的:

在編譯狀態(tài)中,class可以是object對(duì)象的父類,自身類,子類。在這三種情況下Java編譯時(shí)不會(huì)報(bào)錯(cuò)。

在運(yùn)行轉(zhuǎn)態(tài)中,class可以是object對(duì)象的父類,自身類,不能是子類。在前兩種情況下result的結(jié)果為true,最后一種為false。但是class為子類時(shí)編譯不會(huì)報(bào)錯(cuò)。運(yùn)行結(jié)果為false。

例子:

接口Person

public interface Person {

public void eat();

}

實(shí)現(xiàn)類People

public class People implements Person {

private int a=0;

@Override

public void eat() {

System.out.println("======"+a);

}

}

子類xiaoming:

public class xiaoming extends People {

private String name;

@Override

public void eat() {

System.out.println("+++++++++");

}

}

主函數(shù)

public static void main(String[] args) {

People p=new People();

xiaoming x=new xiaoming();

System.out.println(p instanceof Person);

System.out.println(p instanceof xiaoming); -----2

System.out.println(x instanceof Person);

System.out.println(x instanceof People);

}

注意:上面2處的代碼在編譯時(shí)不會(huì)報(bào)錯(cuò)。

運(yùn)行結(jié)果:

true

false

true

true

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容