JDK14的新特性NullPointerExceptions的使用
JDK 14的新特性:更加好用的NullPointerExceptions
讓99%的java程序員都頭痛的異常就是NullPointerExceptions了。NullPointerExceptions簡(jiǎn)稱NPE,它是運(yùn)行時(shí)異常的一種,也是java程序中最最容易出現(xiàn)的異常。
出現(xiàn)了NullPointerExceptions之后我們?cè)趺刺幚砟兀?/p>
一般情況下就是看日志,看一下到底哪一行出錯(cuò)了。如果這一行只有簡(jiǎn)單的代碼,那么很容易就找到問(wèn)題所在。
要命的是如果這一行很復(fù)雜,那么找出問(wèn)題就不是那么容易了。很有可能我們需要向前debug100行,向后debug50行才能解決。
最大的問(wèn)題就是如果這個(gè)異常出現(xiàn)在線上環(huán)境,debug是不可能debug了。這時(shí)候就要靠你的肉眼,你對(duì)程序的敏感程度再加上你的專業(yè)素養(yǎng),才能從萬(wàn)花叢中找出那個(gè)問(wèn)題。
舉個(gè)例子,我們定義一個(gè)CustUser和Address:
@Data public class CustUser { private String userName; private Address address; }
@Data public class Address { private String addressName; }
再來(lái)產(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行有一長(zhǎng)串代碼,到底是哪里報(bào)了這個(gè)異常呢?
簡(jiǎn)單代碼,比如上面我們提的例子,簡(jiǎn)單分析一下就知道問(wèn)題所在了。但是對(duì)于那么猶如蛛網(wǎng)一樣的復(fù)雜的項(xiàng)目,找起來(lái)就很難了。
別害怕,JEP 358: Helpful NullPointerExceptions就是用來(lái)解決這個(gè)問(wèn)題。
還是上面的例子,還是上面的配方和味道,我們只需要在運(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ò)信息被打印出來(lái)了。你苦思冥想的問(wèn)題解決了。
這個(gè)特性好是好,但是默認(rèn)情況下是被關(guān)閉的。
有利就有弊,我們看下這個(gè)參數(shù)有什么影響:
- 性能影響:因?yàn)橐鎯?chǔ)額外的信息,對(duì) stack trace會(huì)有性能上面的壓力。
- 安全影響:從上面的例子我們可以看到異常信息中包含了非常充分的代碼信息內(nèi)容。如果對(duì)一些機(jī)密應(yīng)用,完全可以通過(guò)異常信息來(lái)推斷代碼邏輯。從而對(duì)安全性造成影響。
- 兼容性:最后是兼容性,之前的JVM可沒(méi)有存儲(chǔ)這些額外的NPE信息,所以可能會(huì)有兼容性的問(wèn)題。
本文的例子:https://github.com/ddean2009/learn-java-base-9-to-20
到此這篇關(guān)于JDK14的新特性NullPointerExceptions的使用的文章就介紹到這了,更多相關(guān)JDK14 NullPointerExceptions內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例)
- windows10 JDK安裝及配置環(huán)境變量與Eclipse安裝教程
- win10 java(jdk安裝)環(huán)境變量配置和相關(guān)問(wèn)題
- Windows10系統(tǒng)下JDK1.8的下載安裝及環(huán)境變量配置的教程
- JDK8新特性之判空遍歷寫(xiě)法
- 深入淺析JDK8新特性之Lambda表達(dá)式
- Java JDK1.5、1.6、1.7新特性整理
- JDK 7 新特性小結(jié)實(shí)例代碼解析
- JDK 14的新特性:文本塊Text Blocks的使用
- JDK10新特性之本地變量類型var的深入理解
相關(guān)文章
SpringBoot-Mail工具實(shí)現(xiàn)郵箱驗(yàn)證碼登錄注冊(cè)功能
現(xiàn)在許多pc程序都有著使用郵箱驗(yàn)證碼實(shí)現(xiàn)登錄注冊(cè)的功能,那么我們應(yīng)該如何完成郵箱驗(yàn)證碼功能呢,我們可以使用springboot內(nèi)置的springboot-mail再結(jié)合redis來(lái)完成這個(gè)功能,感興趣的朋友跟隨小編一起看看吧2024-07-07logback?OutputStreamAppender高效日志輸出源碼解析
這篇文章主要介紹了為大家logback?OutputStreamAppender日志輸出效率提升示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10Java 客戶端操作 FastDFS 實(shí)現(xiàn)文件上傳下載替換刪除功能
這篇文章主要介紹了Java 客戶端操作 FastDFS 實(shí)現(xiàn)文件上傳下載替換刪除功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10在非spring環(huán)境中調(diào)用service中的方法
非Spring環(huán)境指的是不使用Spring框架來(lái)管理和配置應(yīng)用程序的運(yùn)行時(shí)環(huán)境,本文將給大家介紹如何在非spring環(huán)境中調(diào)用service中的方法,文中有詳細(xì)實(shí)現(xiàn)步驟,需要的朋友可以參考下2024-03-03在idea環(huán)境下構(gòu)建springCloud項(xiàng)目
本篇文章主要介紹了在idea環(huán)境下構(gòu)建springCloud項(xiàng)目,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11