0

0

java出现空指针的情况 盘点引发NullPointerException的六大典型场景

畫卷琴夢

畫卷琴夢

发布时间:2026-02-03 14:14:39

|

774人浏览过

|

来源于php中文网

原创

NPE根源是假设引用非空但实际为null,需在设计阶段明确空值契约。常见场景含调用前未判空、自动拆箱、集合元素为null、静态方法误用实例调用、构造器泄露this、多线程共享状态未同步。

java出现空指针的情况 盘点引发nullpointerexception的六大典型场景

调用对象方法前未判空

只要对象引用为 null,直接调用其任何实例方法(包括 toString()equals()hashCode())都会触发 NullPointerException。尤其容易在日志打印、参数校验、DTO 转 VO 等环节忽略。

  • 常见写法:user.getName().length() —— 若 usernull,立刻崩溃
  • 安全写法:先用 Objects.nonNull(user)user != null 判空,再访问;或改用 Optional.ofNullable(user).map(User::getName).orElse("")
  • 注意:String.valueOf(obj)Objects.toString(obj) 可安全处理 null,但它们不解决业务逻辑中对非空的依赖

自动拆箱时包装类为null

Java 在执行 intboolean 等基本类型运算时,会自动将 IntegerBoolean 等包装类拆箱。若该包装类变量本身是 null,就会抛出 NullPointerException,而非 NumberFormatException 或其他异常。

  • 典型场景:Integer status = getStatusFromDB(); if (status == 1) { ... } —— 若 getStatusFromDB() 返回 null,比较时触发 NPE
  • 避免方式:改用 Objects.equals(status, 1),或显式判空 status != null && status == 1
  • 注意:三元表达式如 status != null ? status : 0 是安全的;但 status ?: 0(Kotlin 风格)在 Java 中不合法

集合或数组元素为null后直接使用

ListMap、数组本身不为 null,不代表其中元素也不为 null。取值后未检查就调用方法或参与计算,是高频 NPE 来源。

  • 例如:list.get(0).trim() —— list 不空,但第 0 个元素可能是 null
  • map.get("key").length() —— map 存在,但 key 对应 value 为 null
  • 建议:用 Optional.ofNullable(list.get(0)).map(String::trim).orElse("");或提前过滤掉 null 元素(如 list.stream().filter(Objects::nonNull).collect(...)
  • 特别注意:MyBatis 查询结果映射到 List 时,若数据库字段允许 NULL,对应字段可能被设为 null,而非默认值

静态方法误当成实例方法调用

当把本该通过类名调用的静态方法(如 StringUtils.isEmpty(str)),错误地通过一个可能为 null 的对象引用去调用(如 strUtils.isEmpty(str)),而 strUtils 恰好是 null,就会触发 NPE。

Smart Picture
Smart Picture

Smart Picture 智能高效的图片处理工具

下载

立即学习Java免费学习笔记(深入)”;

  • 本质是「调用空引用的任意方法」,和是否静态无关;JVM 不关心语义,只看接收者是否为 null
  • 排查重点:IDE 中 Ctrl+Click 进入方法签名,确认是 static;调用处是否用了实例变量而非类名
  • 更隐蔽的情况:Lombok 的 @UtilityClass 生成的类,所有方法都是 static,但开发者可能误以为它是普通工具类实例

构造函数中过早暴露 this 引用

在构造器执行完成前,就把 this 发送给其他线程或注册到监听器、缓存、单例容器中,此时对象字段尚未初始化完毕,外部代码拿到该引用并调用其方法,极易因字段为 null 报 NPE。

  • 典型模式:new Task().registerToScheduler(this) —— 构造器里调用了外部方法,并传入 this
  • Spring 中常见于 @PostConstruct 未生效前就发布事件,或在构造器中调用 ApplicationContext.publishEvent()
  • 根本规避方式:禁止在构造器中泄露 this;改用工厂方法 + 初始化回调,或延迟注册到 Bean 生命周期后期(如 afterPropertiesSet

异步/多线程环境下共享对象状态未同步

多个线程共用一个对象,某个线程将字段设为 null,另一线程未加锁就直接访问该字段,可能读到 null 并调用其方法 —— 表现为偶发 NPE,难以复现。

  • 例子:private Cache cache; 被两个线程同时读写,线程 A 执行 cache = null,线程 B 同时执行 cache.get(key)
  • 不是简单加 synchronized 就能解决:要确保「赋值」和「使用」都在同一锁保护下,且锁对象一致
  • 更稳妥做法:用 volatile 修饰引用(仅保证可见性,不保证原子性);或改用线程安全容器如 ConcurrentHashMap;或彻底避免共享可变状态
  • 注意:Spring 默认 singleton Bean 是多线程共享的,字段若可变,必须自行保证线程安全
NPE 的根源永远是「假设了某个引用非空,但实际它就是 null」。比起堆上找哪一行崩了,更关键的是在设计阶段明确每个变量的空值契约:它是否允许为 null?谁负责初始化?谁负责校验?这些约定一旦模糊,再好的 try-catch 也盖不住漏掉的空检查。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

117

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

69

2026.01.26

mybatis一级缓存和二级缓存
mybatis一级缓存和二级缓存

在MyBatis中,一级缓存和二级缓存是两种不同级别的缓存机制,它们都可以用来提高性能。本专题提供mybatis一级缓存和二级缓存相关文章,大家可以免费阅读。

300

2023.08.21

ibatis和mybatis有什么区别
ibatis和mybatis有什么区别

ibatis和mybatis的区别:1、基本信息不同;2、开发时间不同;3、功能与易用性;4、配置文件;5、入参类型与出参类型;6、返回结果集接受方式;7、语法差异;8、数据库方言支持;9、插件支持;10、社区活跃度;11、全球化支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

85

2024.02.23

mybatis如何配置数据库连接
mybatis如何配置数据库连接

mybatis配置数据库连接的方法:1、指定数据源;2、配置事务管理器;3、配置类型处理器和映射器;4、使用环境元素;5、配置别名。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

102

2024.02.23

mybatis工作原理及流程是什么
mybatis工作原理及流程是什么

mybatis工作原理及流程:1、配置文件;2、接口与映射;3、sql解析与生成;4、执行计划;5、结果处理;6、动态sql;7、缓存机制;8、插件;9、事务管理;10、日志与监控;11、扩展性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

155

2024.02.23

hibernate和mybatis有哪些区别
hibernate和mybatis有哪些区别

hibernate和mybatis的区别:1、实现方式;2、性能;3、对象管理的对比;4、缓存机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

148

2024.02.23

Java MyBatis框架
Java MyBatis框架

本专题专注于Java主流ORM框架MyBatis的应用,系统讲解SQL映射、动态SQL、结果映射、分页查询、缓存机制与多表关联等核心内容,并结合企业管理系统、电商平台和后台管理项目实战,帮助学员全面掌握高效的数据库持久层开发技能。

134

2025.08.26

c语言中/相关合集
c语言中/相关合集

本专题整合了c语言中/的用法、含义解释。阅读专题下面的文章了解更多详细内容。

0

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.2万人学习

C# 教程
C# 教程

共94课时 | 8.4万人学习

Java 教程
Java 教程

共578课时 | 56.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号