美文网首页程序那些事Java
JDK 14的新特性:更加好用的NullPointerExcep

JDK 14的新特性:更加好用的NullPointerExcep

作者: flydean程序那些事 | 来源:发表于2020-05-09 06:20 被阅读0次

让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
image

运行一下:

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)

看到不同之处了吗?完整的出错信息被打印出来了。你苦思冥想的问题解决了。

这个特性好是好,但是默认情况下是被关闭的。

有利就有弊,我们看下这个参数有什么影响:

  1. 性能影响:因为要存储额外的信息,对 stack trace会有性能上面的压力。

  2. 安全影响:从上面的例子我们可以看到异常信息中包含了非常充分的代码信息内容。如果对一些机密应用,完全可以通过异常信息来推断代码逻辑。从而对安全性造成影响。

  3. 兼容性:最后是兼容性,之前的JVM可没有存储这些额外的NPE信息,所以可能会有兼容性的问题。

本文的例子https://github.com/ddean2009/learn-java-base-9-to-20

本文作者:flydean程序那些事

本文链接:http://www.flydean.com/jdk-14-nullpointerexceptions/

本文来源:flydean的博客

欢迎关注我的公众号:程序那些事,更多精彩等着您!

相关文章

  • JDK 14的新特性:更加好用的NullPointerExcep

    让99%的java程序员都头痛的异常就是NullPointerExceptions了。NullPointerExc...

  • JDK新特性书目录

    JDK1.4新特性 JDK1.5新特性 JDK1.6新特性 JDK1.7新特性 JDK1.8新特性

  • jdk14新特性

    1 JDK 14新特性即将发布 1.1 JDK 14详细概述 JDK 8 已经在 2014年 3月 18日正式可用...

  • Java14新特性:增强NPE NullPointerExcep

    改进 NullPointerExceptions,通过准确描述哪些变量为 null 来提高 JVM 生成的异常的可...

  • Java学习26:JDK14新特性

    2020年3月17日,Oracle公司正式发布了JDK14。共新增了16项新特性。 新的语言特性 新的语言特性有7...

  • JDK14的新特性

    虽然JDK13在今年的9月17号才发布,但是丝毫不会影响到下一个版本JDK14的开发工作。听说官方定的新功能马上就...

  • JDK14 新特性

    NUMA-Aware Memory Allocation for G1 了解这个特性之前,我们需要了解什么是NUM...

  • jdk13特性

    JDK 13 新特性讲解课程 第一章 JDK 13新特性介绍 1.1 JDK 各版本主要特性回顾 JDK Vers...

  • JDK14新特性介绍

    JDK14新特性介绍 描述 OpenJDK14是Java SE平台的版本14的开源参考实现,由Java社区流程中的...

  • JDK 14的新特性:switch表达式

    简介 switch的新特性可是源远流长,早在JDK 12就以预览功能被引入了,最终在JDK 14成为了正式版本的功...

网友评论

    本文标题:JDK 14的新特性:更加好用的NullPointerExcep

    本文链接:https://www.haomeiwen.com/subject/hmfhnhtx.html