JDK 14的新特性:更加好用的NullPointerExceptions
JDK 14的新特性:更加好用的NullPointerExceptions
让99%的java程序员都头痛的异常就是NullPointerExceptions了。NullPointerExceptions简称NPE,它是运行时异常的一种,也是java程序中最最容易出现的异常。
出现了NullPointerExceptions之后我们怎么处理呢?
一般情况下就是看日志,看一下到底哪一行出错了。如果这一行只有简单的代码,那么很容易就找到问题所在。
要命的是如果这一行很复杂,那么找出问题就不是那么容易了。很有可能我们需要向前debug100行,向后debug50行才能解决。
最大的问题就是如果这个异常出现在线上环境,debug是不可能debug了。这时候就要靠你的肉眼,你对程序的敏感程度再加上你的专业素养,才能从万花丛中找出那个问题。
举个例子,我们定义一个CustUser和Address:
@Data
public class CustUser {
    private String userName;
    private Address address;
}
@Data
public class Address {
    private String addressName;
}
再来产生一个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());
    }
}
上面代码中的最后一行,因为addressName是空的,所以在调用toLowerCase的时候会抛出NPE。运行结果如下:
Exception in thread "main" java.lang.NullPointerException
	at com.flydean.nullpointerexceptions.NPEUsage.main(NPEUsage.java:16)
上述异常只告诉我们有一个NPE在第16行。但是16行有一长串代码,到底是哪里报了这个异常呢?
简单代码,比如上面我们提的例子,简单分析一下就知道问题所在了。但是对于那么犹如蛛网一样的复杂的项目,找起来就很难了。
别害怕,JEP 358: Helpful NullPointerExceptions就是用来解决这个问题。
还是上面的例子,还是上面的配方和味道,我们只需要在运行时加上下面的参数:
-XX:+ShowCodeDetailsInExceptionMessages

运行一下:
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)
看到不同之处了吗?完整的出错信息被打印出来了。你苦思冥想的问题解决了。
这个特性好是好,但是默认情况下是被关闭的。
有利就有弊,我们看下这个参数有什么影响:
- 性能影响:因为要存储额外的信息,对 stack trace会有性能上面的压力。 
- 安全影响:从上面的例子我们可以看到异常信息中包含了非常充分的代码信息内容。如果对一些机密应用,完全可以通过异常信息来推断代码逻辑。从而对安全性造成影响。 
- 兼容性:最后是兼容性,之前的JVM可没有存储这些额外的NPE信息,所以可能会有兼容性的问题。 
本文的例子https://github.com/ddean2009/learn-java-base-9-to-20
欢迎关注我的公众号:程序那些事,更多精彩等着您!
更多内容请访问 www.flydean.com
JDK 14的新特性:更加好用的NullPointerExceptions的更多相关文章
- JDK 14的新特性:instanceof模式匹配
		JDK 14的新特性:instanceof模式匹配 JDK14在2020年的3月正式发布了.可惜的是正式特性只包含了最新的Switch表达式,而Records,patterns,text blocks ... 
- Java 15 正式发布, 14 个新特性,刷新你的认知!!
		JDK 15 2020/09/15 如期而至! 这个时间牛逼啊,和苹果发布会同天? OracleJDK 15 发布地址: https://www.oracle.com/java/technologie ... 
- 译文《全新首发JDK 16全部新特性》
		封面:洛小汐 译者:潘潘 JDK 8 的新特性都还没摸透,JDK 16 的新特性就提着刀来了. 郑重申明: 第一次冒险翻译专业领域的文献,可想而知,效果特别糟糕.一般翻译文献特别是 技术专业领域 的内 ... 
- JDK 5 ~ 10 新特性倾情整理!
		JDK 5 ~ 10 新特性倾情整理! 最近连 JDK11都在准备发布的路上了,大家都整明白了吗?也许现在大部分人还在用6-8,8的新特性都没用熟,9刚出不久,10-11就不用说了. 为了大家对JDK ... 
- Java JDK 1.7 和 JDK 1.8 新特性
		0 引言 本文主要介绍 Java JDK 中 1.7 和 1.8 的新特性. 1 JDK 1.7 新特性 1. switch可以接受String类型: public class Switch { pu ... 
- JDK各版本新特性!
		1.JDK1.5 新特性 1.自动装箱与拆箱:自动装箱的过程:每当需要一种类型的对象时,这种基本类型就自动地封装到与它相同类型的包装中.自动拆箱的过程:每当需要一个值时,被装箱对象中的值就被自动地提取 ... 
- Java 9的14个新特性总结
		Java 9 包含了丰富的特性集.虽然Java 9没有新的语言概念,但是有开发者感兴趣的新的API和诊断命令. 我们将快速的,着重的浏览其中的几个新特性: 模块化系统–Jigsaw 项目 模块化是一 ... 
- JDK 5 ~ 11 新特性倾情整理
		为了大家对JDK有一个全面的了解,下面我为大家整理了JDK5~11的所有关键新特性! 先看一下JDK的版本迭代图: 注: OpenJDK和JDK区别 GPL协议通用性公开许可证(General ... 
- JDK 1.8 新特性之Date-Time API
		来源:请点击查看 1.8之前的日期类: 线程不安全:java.util.Date 这个类线程不安全,而且所有日期类都是可变的. 时间处理麻烦:默认的开始日期从1900年,不支持国际化,不提供时区支持, ... 
随机推荐
- D - Expanding Rods POJ - 1905(二分)
			D - Expanding Rods POJ - 1905 When a thin rod of length L is heated n degrees, it expands to a new l ... 
- C/C++知识总结 五  复合数据类型 壹(数组、字符串与string、结构)
			C/C++复合数据类型 壹(数组.结构) 数组 数组的意义.定义与创建 一.二维数组应用 字符数组与字符串处理函数 数组与指针---关系密切 数组的意义与定义创建 意义:反映数据间的特点(通过把同一类 ... 
- Maven快照版本要这样用才真的香!
			Bug的身世之谜 今天又分享一个问题解决的故事.请看下图框起来的错误,明显就是找不到这个class嘛! 下面我们按照正常人的思路去排查这个问题,既然找不到class那就先看这个依赖的jar包有没有,如 ... 
- 各种版本docker下载的中国开源地址
			最近在群里听说Docker很火,于是自己抱着试试的态度,想玩玩,可是遇到了一些问题,记录下来,方便备忘,也方便防止大家被坑. 我的虚拟机装的是centos 6.5,百度了好多教程,丫的,都不解释,就一 ... 
- .NET Core项目部署到Linux(Centos7)(十)总结
			目录 1.前言 2.环境和软件的准备 3.创建.NET Core API项目 4.VMware Workstation虚拟机及Centos 7安装 5.Centos 7安装.NET Core环境 6. ... 
- 给定一个整数数组 nums 和一个目标值 target,求nums和为target的两个数的下表
			这个是来自力扣上的一道c++算法题目: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案 ... 
- Linux下修改efi启动项
			Linux下有一个efibootmgr工具可以编辑efi启动项,十分方便,简单介绍如下 直接运行efibootmgr会显示出当前所有efi启动项,每个启动项前都有相应编号, 可以使用efibootmg ... 
- javascript 入门 之 bootstrap/bootstrap-table 安装方法
			也和select2一样,可以有三种方法 1.远程调用CDN 2.用bower安装 3.下载 时间原因,暂时先讲第二种,其余两种,以后完善 1.进入根目录,执行bower install bootstr ... 
- "斜体显示"组件:<i> —— 快应用组件库H-UI
			 <import name="i" src="../Common/ui/h-ui/text/c_tag_i"></import> &l ... 
- "三号标题"组件:<h3> —— 快应用组件库H-UI
			 <import name="h3" src="../Common/ui/h-ui/text/c_h3"></import> < ... 
