JDK14的新特性NullPointerExceptions的使用
JDK 14的新特性:更加好用的NullPointerExceptions
讓99%的java程序員都頭痛的異常就是NullPointerExceptions了。NullPointerExceptions簡稱NPE,它是運(yùn)行時(shí)異常的一種,也是java程序中最最容易出現(xiàn)的異常。
出現(xiàn)了NullPointerExceptions之后我們怎么處理呢?
一般情況下就是看日志,看一下到底哪一行出錯(cuò)了。如果這一行只有簡單的代碼,那么很容易就找到問題所在。
要命的是如果這一行很復(fù)雜,那么找出問題就不是那么容易了。很有可能我們需要向前debug100行,向后debug50行才能解決。
最大的問題就是如果這個(gè)異常出現(xiàn)在線上環(huán)境,debug是不可能debug了。這時(shí)候就要靠你的肉眼,你對程序的敏感程度再加上你的專業(yè)素養(yǎng),才能從萬花叢中找出那個(gè)問題。
舉個(gè)例子,我們定義一個(gè)CustUser和Address:
@Data
public class CustUser {
private String userName;
private Address address;
}
@Data
public class Address {
private String addressName;
}
再來產(chǎn)生一個(gè)NPE:
@Slf4j
public class NPEUsage {
public static void main(String[] args) {
Address address=new Address();
CustUser custUser=new CustUser();
custUser.setAddress(address);
log.info(custUser.getAddress().getAddressName().toLowerCase());
}
}
上面代碼中的最后一行,因?yàn)閍ddressName是空的,所以在調(diào)用toLowerCase的時(shí)候會(huì)拋出NPE。運(yùn)行結(jié)果如下:
Exception in thread "main" java.lang.NullPointerException
at com.flydean.nullpointerexceptions.NPEUsage.main(NPEUsage.java:16)
上述異常只告訴我們有一個(gè)NPE在第16行。但是16行有一長串代碼,到底是哪里報(bào)了這個(gè)異常呢?
簡單代碼,比如上面我們提的例子,簡單分析一下就知道問題所在了。但是對于那么猶如蛛網(wǎng)一樣的復(fù)雜的項(xiàng)目,找起來就很難了。
別害怕,JEP 358: Helpful NullPointerExceptions就是用來解決這個(gè)問題。
還是上面的例子,還是上面的配方和味道,我們只需要在運(yùn)行時(shí)加上下面的參數(shù):
-XX:+ShowCodeDetailsInExceptionMessages

運(yùn)行一下:
Exception in thread "main" java.lang.NullPointerException: Cannot invoke "String.toLowerCase()" because the return value of "com.flydean.nullpointerexceptions.Address.getAddressName()" is null
at com.flydean.nullpointerexceptions.NPEUsage.main(NPEUsage.java:16)
看到不同之處了嗎?完整的出錯(cuò)信息被打印出來了。你苦思冥想的問題解決了。
這個(gè)特性好是好,但是默認(rèn)情況下是被關(guān)閉的。
有利就有弊,我們看下這個(gè)參數(shù)有什么影響:
- 性能影響:因?yàn)橐鎯?chǔ)額外的信息,對 stack trace會(huì)有性能上面的壓力。
- 安全影響:從上面的例子我們可以看到異常信息中包含了非常充分的代碼信息內(nèi)容。如果對一些機(jī)密應(yīng)用,完全可以通過異常信息來推斷代碼邏輯。從而對安全性造成影響。
- 兼容性:最后是兼容性,之前的JVM可沒有存儲(chǔ)這些額外的NPE信息,所以可能會(huì)有兼容性的問題。
本文的例子:https://github.com/ddean2009/learn-java-base-9-to-20
到此這篇關(guān)于JDK14的新特性NullPointerExceptions的使用的文章就介紹到這了,更多相關(guān)JDK14 NullPointerExceptions內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例)
- windows10 JDK安裝及配置環(huán)境變量與Eclipse安裝教程
- win10 java(jdk安裝)環(huán)境變量配置和相關(guān)問題
- Windows10系統(tǒng)下JDK1.8的下載安裝及環(huán)境變量配置的教程
- JDK8新特性之判空遍歷寫法
- 深入淺析JDK8新特性之Lambda表達(dá)式
- Java JDK1.5、1.6、1.7新特性整理
- JDK 7 新特性小結(jié)實(shí)例代碼解析
- JDK 14的新特性:文本塊Text Blocks的使用
- JDK10新特性之本地變量類型var的深入理解
相關(guān)文章
Java使用分治算法實(shí)現(xiàn)排序數(shù)索引功能示例【二分搜索】
這篇文章主要介紹了Java使用分治算法實(shí)現(xiàn)排序數(shù)索引功能,結(jié)合具體實(shí)例形式分析了java分治算法進(jìn)行排序索引的相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
MyBatisPlus自定義SQL的實(shí)現(xiàn)
MyBatisPlus提供了自定義SQL功能,允許開發(fā)者在Mapper接口中定義方法,并通過XML文件或注解編寫SQL語句,本文詳解了如何在MP中使用自定義SQL,感興趣的可以了解一下2024-09-09
Java遞歸讀取文件例子_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
本文通過一段示例代碼給大家介紹了java遞歸讀取文件的方法,代碼簡單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-05-05
淺談java多態(tài)的實(shí)現(xiàn)主要體現(xiàn)在哪些方面
下面小編就為大家?guī)硪黄獪\談java多態(tài)的實(shí)現(xiàn)主要體現(xiàn)在哪些方面。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09
快速解決List集合add元素,添加多個(gè)對象出現(xiàn)重復(fù)的問題
這篇文章主要介紹了快速解決List集合add元素,添加多個(gè)對象出現(xiàn)重復(fù)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08

