踩坑记录(Long[]ids)

2024-09-06 12:20
文章标签 记录 long ids

本文主要是介绍踩坑记录(Long[]ids),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主要针对Long[] ids 的判空问题

问题代码

   public void delYnjC(Long[] ids) {if (CollectionUtils.isEmpty(Collections.singleton(ids))) {throw new NullPointerException("参数不能为空");}naturalYnjCMapper.delYnjC(ids);}

修正后代码

   public void delYnjC(Long[] ids) {// 检查数组是否为null或长度为0if (ids == null || ids.length == 0) {throw new IllegalArgumentException("参数不能为空");}// 执行删除操作naturalYnjCMapper.delYnjC(ids);}

修正原因

  1. 使用 Collections.singleton(ids)Collections.singleton 方法通常用于创建一个只包含单个元素的不可变集合。当你传递一个数组 ids 给它时,实际上创建了一个只包含 ids 这个数组对象的集合。因此,CollectionUtils.isEmpty 方法只会检查这个集合是否为空,而不是检查 ids 数组是否为空。

     

    正确的做法应该是直接检查 ids 数组是否为 null 或者长度是否为 0

     2.异常类型:如果参数为空或不合法,应该抛出 IllegalArgumentException 而不是     NullPointerException,因为问题在于参数的有效性而非 null 值。

相关知识详解

Collections.singleton()

Collections.singleton() 是 Java 集合框架中的一个方法,它属于 java.util.Collections 类。这个方法主要用于创建一个只包含一个元素的不可变集合(Set)。当你需要一个单元素的集合,并且希望这个集合在之后的操作中不会被修改时,这个方法就非常有用。

使用方法

singleton 方法的签名如下:

public static <T> Set<T> singleton(T o)

这里 <T> 表示泛型类型参数,o 是传入的对象,这个对象将成为返回的集合中的唯一元素。

返回值

这个方法返回一个实现了 Set 接口的集合,这个集合只能包含一个指定的元素。返回的集合是不可变的,这意味着你不能向其中添加或删除元素。

注意事项
  • 不可变性:返回的集合是不可变的,任何尝试修改它的操作都会抛出 UnsupportedOperationException
  • 元素限制:该集合只能包含一个元素,因此试图添加另一个元素将导致异常。
  • 性能优化:由于集合只包含一个元素并且是不可变的,所以在内部实现上可能会有优化,比如使用更简单的数据结构来存储元素。
  • 元素引用:如果你传递给 singleton 的对象本身是可变的,那么这个对象的状态仍然可以被外部代码改变,尽管集合本身是不可变的。

不可变案例:

import java.util.Set;
import java.util.Collections;public class SingletonExample {public static void main(String[] args) {String singleElement = "Hello";Set<String> singletonSet = Collections.singleton(singleElement);// 输出集合System.out.println(singletonSet); // 输出 [Hello]// 尝试添加新元素会失败try {singletonSet.add("World");} catch (UnsupportedOperationException e) {System.out.println("Cannot add element to singleton set.");}}
}

可变案例:

假设我们有一个 Person 类,它可以改变自己的名字:

public class Person {private String name;public Person(String name) {this.name = name;}public String getName() {return name;}public void setName(String name) {this.name = name;}@Overridepublic String toString() {return "Person{" +"name='" + name + '\'' +'}';}
}

创建一个包含一个 Person 对象的 Collections.singleton() 集合,并尝试修改该对象的状态:

import java.util.Collections;
import java.util.Set;public class SingletonExample {public static void main(String[] args) {Person person = new Person("Alice");// 创建一个只包含一个元素的不可变集合Set<Person> singletonSet = Collections.singleton(person);System.out.println("Before: " + singletonSet); // 输出:[Person{name='Alice'}]// 尽管集合是不可变的,但对象 person 可以被修改person.setName("Bob");// 集合中的对象状态改变了System.out.println("After: " + singletonSet); // 输出:[Person{name='Bob'}]}
}

这个例子中,singletonSet 是一个不可变集合,但它包含的 Person 对象是可以被修改的。通过 person 引用,我们可以改变 Person 对象的名字,这将反映在 singletonSet 集合中,因为集合中的元素实际上就是 person 对象本身。

总结

Collections.singleton() 创建的集合虽然是不可变的,但这并不意味着集合内的对象本身是不可变的。如果集合中的对象是一个可变对象,那么即使集合本身不可变,这个对象的状态仍然可以通过其他引用被修改。

IllegalArgumentException 和NullPointerException详解及应用场景

在 Java 中,IllegalArgumentExceptionNullPointerException 是两种常见的异常类型,它们通常用于处理程序中的逻辑错误或状态错误。这两种异常都是运行时异常(RuntimeException),这意味着它们不需要在方法签名中声明。

IllegalArgumentException

IllegalArgumentException 表示方法接收了不合适的参数。当一个方法接收到的参数值不合适时,就会抛出这种异常。例如,如果一个方法期望一个正整数作为参数,但是接收到的是一个负数或者零,这时就应该抛出 IllegalArgumentException

特点
  • 属于 RuntimeException,不需要在方法签名中声明。
  • 通常用来指示参数的值不符合预期的约束条件。
应用场景

1.数值范围检查:当方法要求参数必须在某个特定范围内时。

public void divide(int numerator, int denominator) {if (denominator == 0) {throw new IllegalArgumentException("Denominator cannot be zero.");}int result = numerator / denominator;System.out.println(result);
}

2.空指针检查:虽然通常使用 NullPointerException 处理 null 参数,但在某些情况下,如果方法不允许参数为 null,则也可以抛出 IllegalArgumentException

public void processString(String str) {if (str == null || str.isEmpty()) {throw new IllegalArgumentException("Input string must not be null or empty.");}System.out.println(str.length());
}

NullPointerException

NullPointerException 是在尝试使用 null 对象实例调用方法或访问其属性时抛出的异常。这是一种非常常见的错误,表明程序试图执行的操作需要一个非空的对象引用。

特点
  • 属于 RuntimeException,不需要在方法签名中声明。
  • 当一个对象引用是 null 但是却像非 null 引用那样被使用时抛出。
应用场景

1.空对象引用:当一个对象引用未正确初始化或赋值时。

public void printMessage(String message) {// 如果 message 是 null,访问 message.length 将会抛出 NPESystem.out.println(message.length());
}

2.数组或集合元素为 null:当遍历数组或集合并尝试使用其中的一个元素时,如果该元素是 null,则可能抛出 NPE。

public void printListElements(List<String> list) {for (String s : list) {// 如果 list 包含 null 元素,则访问 s.length 会抛出 NPESystem.out.println(s.length());}
}
总结
  • IllegalArgumentException 通常用于参数验证,确保传入的参数满足方法的要求。
  • NullPointerException 主要用于处理对象引用为 null 的情况,特别是在调用方法或访问对象属性时。

在编写代码时,合理地使用这些异常可以帮助提高代码的健壮性和可维护性。通过抛出适当的异常,可以更好地控制程序流程,并向调用者传达错误信息。

这篇关于踩坑记录(Long[]ids)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

perl的学习记录——仿真regression

1 记录的背景 之前只知道有这个强大语言的存在,但一直侥幸自己应该不会用到它,所以一直没有开始学习。然而人生这么长,怎就确定自己不会用到呢? 这次要搭建一个可以自动跑完所有case并且打印每个case的pass信息到指定的文件中。从而减轻手动跑仿真,手动查看log信息的重复无效低质量的操作。下面简单记录下自己的思路并贴出自己的代码,方便自己以后使用和修正。 2 思路整理 作为一个IC d

SSM项目使用AOP技术进行日志记录

本步骤只记录完成切面所需的必要代码 本人开发中遇到的问题: 切面一直切不进去,最后发现需要在springMVC的核心配置文件中中开启注解驱动才可以,只在spring的核心配置文件中开启是不会在web项目中生效的。 之后按照下面的代码进行配置,然后前端在访问controller层中的路径时即可观察到日志已经被正常记录到数据库,代码中有部分注释,看不懂的可以参照注释。接下来进入正题 1、导入m

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、

Linux常用工具与命令日常记录(长期更新)

Linux常用工具与命令日常记录(长期更新) 目录 1.本地复制到远程2.Linux压缩拆包与解压3.生成随机密码4.ubuntu默认Python版本设置5.计算当前文件夹中文件数量6.windows中编写shell脚本,在Linux运行出错7.history 历史命令显示时间用户8.Ubuntu18.04设置源、网卡9.Ubuntu18.04设置网卡10.Ubuntu:自定义开

Excel和Word日常使用记录:

Excel使用总结 表格颜色填充: 合并单元格: 选中你要合并的单元格区域。按下快捷键 Alt + H,然后松开这些键。再按下 M,接着按 C。这个组合键执行的操作是:Alt + H:打开“主页”选项卡。M:选择“合并单元格”选项。C:执行“合并并居中”操作。 插入行: 在Excel中,插入一行的快捷键是:Windows:选择整行(可以点击行号)。按下 Ctrl + Sh

野火霸天虎V2学习记录

文章目录 嵌入式开发常识汇总1、嵌入式Linux和stm32之间的区别和联系2、stm32程序下载方式3、Keil5安装芯片包4、芯片封装种类5、STM32命名6、数据手册和参考手册7、什么是寄存器、寄存器映射和内存映射8、芯片引脚顺序9、stm32芯片里有什么10、存储器空间的划分11、如何理解寄存器说明12、如何操作寄存器的某一位 STM32F407芯片学习1、stm32单片机启动流程s

【20240907问题记录(未解决)】Conda环境问题:SSH与本地环境变量不一致

Conda 允许用户在同一系统上创建多个独立的Python环境。然而,最近遇到了一个奇怪的问题:通过SSH连接到远程Ubuntu机器时,Conda环境变量的行为与本地机器不一致。以下是具体遇到的问题: 1. 问题描述 在本地Ubuntu机器上,我的conda的python版本是3.6,而pip版本可以通过命令 pip --version 查看,显示为: pip 21.3.1 from /ho