JDK14的新特性NullPointerExceptions的使用

 更新时间:2020年04月28日 10:47:05   作者:flydean  
这篇文章主要介绍了JDK14的新特性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

到此这篇关于JDK14的新特性NullPointerExceptions的使用的文章就介绍到这了,更多相关JDK14 NullPointerExceptions内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java中Websocket的使用方法例子

    java中Websocket的使用方法例子

    这篇文章主要给大家介绍了关于java中Websocket的使用方法,WebSocket是HTML5开始提供的一种在浏览器和服务器间进行全双工通信的协议,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • Java使用FTPClient类读写FTP

    Java使用FTPClient类读写FTP

    这篇文章主要为大家详细介绍了Java使用FTPClient类读写FTP的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • SpringBoot-Mail工具实现邮箱验证码登录注册功能

    SpringBoot-Mail工具实现邮箱验证码登录注册功能

    现在许多pc程序都有着使用邮箱验证码实现登录注册的功能,那么我们应该如何完成邮箱验证码功能呢,我们可以使用springboot内置的springboot-mail再结合redis来完成这个功能,感兴趣的朋友跟随小编一起看看吧
    2024-07-07
  • Java读取并下载网络文件的方法

    Java读取并下载网络文件的方法

    这篇文章主要为大家详细介绍了Java读取并下载网络文件的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • java自定义类加载器代码示例

    java自定义类加载器代码示例

    这篇文章主要介绍了java自定义类加载器代码示例,具有一定借鉴价值,需要的朋友可以了解下。
    2017-12-12
  • logback OutputStreamAppender高效日志输出源码解析

    logback OutputStreamAppender高效日志输出源码解析

    这篇文章主要介绍了为大家logback OutputStreamAppender日志输出效率提升示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Java 客户端操作 FastDFS 实现文件上传下载替换删除功能

    Java 客户端操作 FastDFS 实现文件上传下载替换删除功能

    这篇文章主要介绍了Java 客户端操作 FastDFS 实现文件上传下载替换删除功能,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • JBoss5.x下配置Log4j方法介绍

    JBoss5.x下配置Log4j方法介绍

    这篇文章主要介绍了JBoss5.x下配置Log4j方法介绍,小编觉得挺不错的,这里分享给大家,供需要的朋友参考。
    2017-10-10
  • 在非spring环境中调用service中的方法

    在非spring环境中调用service中的方法

    非Spring环境指的是不使用Spring框架来管理和配置应用程序的运行时环境,本文将给大家介绍如何在非spring环境中调用service中的方法,文中有详细实现步骤,需要的朋友可以参考下
    2024-03-03
  • 在idea环境下构建springCloud项目

    在idea环境下构建springCloud项目

    本篇文章主要介绍了在idea环境下构建springCloud项目,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11

最新评论