NullPointerException 处理规范 --- 记一次空指针引起的小组风波

本文主要是介绍NullPointerException 处理规范 --- 记一次空指针引起的小组风波,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

All input is evil。

        一切的入参都是邪恶的,作为编码人员都无法掌握。如果不针对这些参数做校验,我们的程序就会出现这样或那样的问题。NullPointerException作为一个老生常谈的话题,我这里又把它拎出来了。
        本次讨论这个话题源于司内一个案例的NullPointerException的复盘。下面我贴一下相关代码。因为涉及到公司的业务源码,会有一定的隐饰。
        

/*** 出现NullPointerException位置已经标出,大家自行阅读* InnerException 是一个自定义异常* @param ids* @return* @throws InnerException*/public Map<String, List<User>> getAdCards(List<String> ids) throws InnerException {List<Long> userIds = decodeLiveIds(ids);List<User> Users = liveBiz.getUsers(getUserIdOrNull(), userIds);return users;}private List<Long> decodeLiveIds(List<String> userIds) throws InnerException {List<Long> ids = new ArrayList<>();for (String userId : userIds) { //此处出现NullPointerExceptionids.add(UserUtil.decode(userId));}return ids;}

        其实一开始我是这样想的,我觉得“所有的公共方法一定要可接受所有可能的参数。因为我们不知道调用公共方法的developer对公共方法的入参全部情景考虑周全,并对入参做全场景校验”

       但是我的同事一开始是这样想的“单个方法只做一件事,符合单一职责原则。把校验规则放到上层,本抽取方法只做解密操作”

        由此看来,我们针对此问题有一个共同点 - “此处参数要做校验

        我们不同的观点是 - “做校验的位置

 针对这种情况,大家一般是怎么处理的呢?大家可以自行考虑下再向下阅读。

经过复盘总结,结合业内规范和笔者公司的规范,最终给出如下建议供大家遵循:

  • 对外提供的开放接口,不管是RPC/API/HTTP接口,必须做参数校验;

  •  极有可能被循环调用的方法,但在方法说明里必须注明外部参数检查,不需要做方法校验;

  • 被声明为private只会被自己代码所调用的方法。如果能够确定调用方法的代码传入参数已经做过检查或者肯定不会有问题,此时可以不校验参数。

        

针对笔者给到的建议,大家可在评论区留言自己的观点,大家一起探讨!

附:

       复盘后,司内是在调用方做的参数校验,并在被调用方的方法描述中添加可用入参描述!

这篇关于NullPointerException 处理规范 --- 记一次空指针引起的小组风波的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1049935

相关文章

Python处理函数调用超时的四种方法

《Python处理函数调用超时的四种方法》在实际开发过程中,我们可能会遇到一些场景,需要对函数的执行时间进行限制,例如,当一个函数执行时间过长时,可能会导致程序卡顿、资源占用过高,因此,在某些情况下,... 目录前言func-timeout1. 安装 func-timeout2. 基本用法自定义进程subp

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.