java 中的instanceof用法詳解及instanceof是什么意思(推薦)
好,應大家的要求先給大家說下在JAVA程序中instanceof是什么意思
instanceof是Java的一個二元操作符,和==,>,<是同一類東東。由于它是由字母組成的,所以也是Java的保留關鍵字。它的作用是測試它左邊的對象是否是它右邊的類的實例,返回boolean類型的數(shù)據(jù)。
instanceof運算符用法
運算符是雙目運算符,左面的操作元是一個對象實例,右面是一個類.當左面的對象是右面的類創(chuàng)建的對象時,該運算符運算的結(jié)果是true,否則是false
說明:
(1).一個類的實例包括本身的實例,以及所有直接或間接子類的實例
(2).instanceof左邊操作元顯式聲明的類型與右邊操作元必須是同種類或有繼承關系,
即位于繼承樹的同一個分支上,否則會編譯出錯
double obj=1;
if(obj instanceof Double){
System.out.println("true");
}
報 "Incompatible conditional operand types double and Double" 錯誤
obj 必須是對象的實例。不能是基礎數(shù)據(jù)類型?!?/p>
String obj=1.0+"";
if(obj instanceof Double){
System.out.println("true");
}
報 "Incompatible conditional operand types String and Double" 錯誤
String 和 Double 不是位于繼承樹的同一個分支上。
if(null instanceof Object){
System.out.println("true");
}else{
System.out.println("false");
}
String obj=null;
if(obj instanceof Object){
System.out.println("true");
}else{
System.out.println("false");
}
打印都為 false. null用操作符instanceof測試任何類型時都是返回false的。
if(obj instanceof null){
System.out.println("true");
}else{
System.out.println("false");
}
編譯出錯。報"Syntax error on token "null", invalid ReferenceType" 錯誤。
public class Test {
public static void main(String[] args){
System.out.println(new Student() instanceof String); //compile time error
System.out.println(new Student() instanceof Exception); //compile time error
System.out.println(new Student() instanceof Object); //compilation and output true
System.out.println(new Student() instanceof List); //compilation and output false
System.out.println(new Student() instanceof List<?>); //compilation and output false
System.out.println(new Student() instanceof List<String>); //compile time error
System.out.println(new Student() instanceof List<Object>); //compile time error
System.out.println(new String() instanceof List); //compile time error
System.out.println(new String() instanceof List<?>); //compile time error
System.out.println(null instanceof Object); //compilation and output false
}
}
class Student{
}
看到上面的測試結(jié)果可能會有這樣那樣的疑惑,為什么Student對象測試String的時候是編譯錯誤,而測試List的時候又能夠通過(難道是instanceof對接口在編譯時不作檢查呢,還是由于List類型本身在編譯時不確定具體類型導致的),但是后面你又會發(fā)現(xiàn)如果是List<String>的時候編譯就不通過了(看來前面的猜測是錯誤的,他對接口是要做檢查的),可是往后面看,你又會納悶String測試List還是List<?>的時候,直接在編譯期就報錯了,這跟Student對象測試List和List<?>的結(jié)果大不同,可能此時你有點相當不解了。我們這個時候翻看java對instanceof操作符的說明時,發(fā)現(xiàn)instanceof的這些表現(xiàn)都是跟cast操作符是有點關系的,就是說當我們在instanceof方法時,編譯器會檢查這個對象能夠cast到右邊的類型,如果不能cast則直接報錯,如果不能確定類型,則通過編譯,具體看運行時定。
這里可能還有一個疑惑,我們Student已經(jīng)確定類型了啊,List類型也是確定的啊,為什么能夠編譯通過呢,而String卻不行呢(難道是自己定義的類和系統(tǒng)定義的類在編譯處理上有不同),這里java沒有做特別的說明,但是我想可能是因為final關鍵字的區(qū)別造成的,我們發(fā)現(xiàn)不論String、Integer、Long等都是最終類,他們的處理類似于編譯器對常量的處理,因為編譯器知道這個類在運行期間是不會有改變的,故而編譯器在編譯期間認為他自己能夠確定這個類的最終類型。而對于自己定義的類呢(我試過系統(tǒng)的非最終類Hashtable、HashMap等,測試和我們自定義的類的結(jié)果一樣,可以通過編譯),由于不是最終類,可能編譯器認為他可能在運行期間會有改變的可能,故而不把他作最為確定的類型處理,故而可以通過編譯。其實當我們在自定義的類前面加上final關鍵字的時候,其表現(xiàn)就跟String、Integer、Long這些最終類測試instanceof表現(xiàn)的一樣了。
好,下面通過實例代碼看下java中instanceof用法
java 中的instanceof 運算符是用來在運行時指出對象是否是特定類的一個實例。instanceof通過返回一個布爾值來指出,這個對象是否是這個特定類或者是它的子類的一個實例。
用法:
result = object instanceof class
參數(shù):
Result:布爾類型。
Object:必選項。任意對象表達式。
Class:必選項。任意已定義的對象類。
說明:
如果 object 是 class 的一個實例,則 instanceof 運算符返回 true。如果 object 不是指定類的一個實例,或者 object 是 null,則返回 false。
示例代碼如下:
package com.instanceoftest;
interface A{}
class B implements A{
}
class C extends B {
}
class instanceoftest {
public static void main(String[] args){
A a=null;
B b=null;
boolean res;
System.out.println("instanceoftest test case 1: ------------------");
res = a instanceof A;
System.out.println("a instanceof A: " + res);
res = b instanceof B;
System.out.println("b instanceof B: " + res);
System.out.println("/ninstanceoftest test case 2: ------------------");
a=new B();
b=new B();
res = a instanceof A;
System.out.println("a instanceof A: " + res);
res = a instanceof B;
System.out.println("a instanceof B: " + res);
res = b instanceof A;
System.out.println("b instanceof A: " + res);
res = b instanceof B;
System.out.println("b instanceof B: " + res);
System.out.println("/ninstanceoftest test case 3: ------------------");
B b2=(C)new C();
res = b2 instanceof A;
System.out.println("b2 instanceof A: " + res);
res = b2 instanceof B;
System.out.println("b2 instanceof B: " + res);
res = b2 instanceof C;
System.out.println("b2 instanceof C: " + res);
}
}
/*
result:
instanceoftest test case 1: ------------------
a instanceof A: false
b instanceof B: false
instanceoftest test case 2: ------------------
a instanceof A: true
a instanceof B: true
b instanceof A: true
b instanceof B: true
instanceoftest test case 3: ------------------
b2 instanceof A: true
b2 instanceof B: true
b2 instanceof C: true
*/
總結(jié)
以上所述是小編給大家介紹的java 中的instanceof用法詳解及instanceof是什么意思,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- JavaScript中isPrototypeOf函數(shù)
- JS中的hasOwnProperty()和isPrototypeOf()屬性實例詳解
- JavaScript中isPrototypeOf函數(shù)作用和使用實例
- js中的hasOwnProperty和isPrototypeOf方法使用實例
- JavaScript isPrototypeOf和hasOwnProperty使用區(qū)別
- Javascript typeof與instanceof的區(qū)別
- JavaScript的instanceof運算符學習教程
- JavaScript中instanceof運算符的使用示例
- JavaScript中instanceof運算符的用法總結(jié)
- JavaScript instanceof 的使用方法示例介紹
- JavaScript中isPrototypeOf、instanceof和hasOwnProperty函數(shù)的用法詳解
相關文章
一文詳解SpringMVC中的@RequestMapping注解
@RequestMapping是一個用于映射HTTP請求到處理方法的注解,在Spring框架中使用,它可以用于控制器類和處理方法上,用來指定處理不同URL路徑的請求,并定義請求的方法等,本文小編將給大家詳細的介紹一下SpringMVC中的@RequestMapping注解,需要的朋友可以參考下2023-08-08
Java調(diào)用py或者exe文件實現(xiàn)Word轉(zhuǎn)PDF
這篇文章主要為大家詳細介紹了Java如何調(diào)用py或者exe文件實現(xiàn)Word轉(zhuǎn)PDF效果,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解下2025-03-03
Spring?Cloud?Gateway編碼實現(xiàn)任意地址跳轉(zhuǎn)的示例
本文主要介紹了Spring?Cloud?Gateway編碼實現(xiàn)任意地址跳轉(zhuǎn)的示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12

