List list=new ArrayList()抛出的ArrayIndexOutOfBoundsException异常

1.应用场景,今天生产日志监控到一组new ArrayList() 进行add 异常,具体日志如下:

java 复制代码
eptionHandler.handler(178): TXXYBUSSINESS|执行异常
java.util.concurrent.CompletionException: java.lang.ArrayIndexOutOfBoundsException: Index 1 out of bounds for length 0
	at java.util.concurrent.CompletableFuture.encodeThrowable(CompletableFuture.java:315) ~[?:?]
	at java.util.concurrent.CompletableFuture.completeThrowable(CompletableFuture.java:320) ~[?:?]
	at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1807) ~[?:?]
	at com.txxy.common.support.ThreadContextTaskDecorator.lambda$decorate$0(ThreadContextTaskDecorator.java:20) ~[txxy-common.jar:10.3.10-SNAPSHOT]
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1136) ~[?:?]
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635) ~[?:?]
	at java.lang.Thread.run(Thread.java:833) ~[?:?]
Caused by: java.lang.ArrayIndexOutOfBoundsException: Index 1 out of bounds for length 0
	at java.util.ArrayList.add(ArrayList.java:455) ~[?:?]
	at java.util.ArrayList.add(ArrayList.java:467) ~[?:?]
	at com.txxy.api.support.PersonalRiskReportSupport.lambda$riskType4$28(PersonalRiskReportSupport.java:528) ~[classes/:?]
	at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1804) ~[?:?]

具体代码:

java 复制代码
List<DTO> riskSummaryList = new ArrayList<>();
                        // 10条记录批量查询
                        Lists.partition(ids, Paging.DEF_PAGE_SIZE).forEach(arrIds -> {
                            List<CompletableFuture<Void>> list =
                                arrIds.stream().map(id -> CompletableFuture.runAsync(() -> {
                                    try {
                                     // ....代码省略了http请求 得到的responseDetail 结果集
                                       
                                        if (responseDetail.isSuccess()) {
                                            riskSummaryList.add(new DTO() );
                                        }
                                    } catch (TxxyBusinessException e) {
                                      
                                    }
                                }, apiTaskExecutor)).collect(Collectors.toList());
                            list.stream().map(CompletableFuture::join).collect(Collectors.toList());

                        });

                        result.setRiskSummaryList(riskSummaryList);

上面代码是对ids 分片按照10条记录查询远程接口,并将结果集放到list riskSummaryList 对象中 riskSummaryList.add(new DTO() )最后输出结果,代码比较简单.

分析:这种情况属于多线程并发产生的,ArrayList是一个非线程安全对象,在并发操作同一个对象时就可能出现上面的异常 情况,ArrayList 源码中ensureCapacity 这个方法是非线程安全的导致计算值扩容不够抛出的异常。

查看ArrayList 源码:

解决方法:

1.使用官网提供的方法Collections.synchronizedList

java 复制代码
  List list = Collections.synchronizedList(new ArrayList(...));

2.new一个对象CopyOnWriteArrayList方法

java 复制代码
new CopyOnWriteArrayList<>()

最后希望能帮助到你解决问题,或是评论区留言问题进行讨论~

相关推荐
小妖同学学AI几秒前
架构图即代码:GitHub星标41.9k的Diagrams,用Python解放你的画图生产力
开发语言·python·github
第一程序员6 分钟前
2026年Python就业市场分析:非科班转码者的机会与挑战
python·github
Thanks_ks7 分钟前
【第 002 讲】Python 标准开发环境搭建:运行环境 | 环境变量 | IDE 部署 | 配置优化
ide·python·pycharm·开发工具·环境配置·环境变量·编程基础
雷帝木木7 分钟前
Python 中的配置文件管理:从基础到高级应用
人工智能·python·深度学习·机器学习
郝学胜-神的一滴8 分钟前
Python 鸭子类型:优雅的多态哲学,让代码更自由
linux·服务器·开发语言·python·网络协议
小龙报9 分钟前
【必装软件】python及pycharm的安装与环境配置
开发语言·人工智能·python·语言模型·自然语言处理·pycharm·语音识别
QQ_1880838009 分钟前
python+flask+vue在线宠物医疗预约平台的设计与实现_b5z03zls
vue.js·python·flask
星辰徐哥9 分钟前
Python 基础与环境配置
开发语言·python
雷帝木木13 分钟前
Python元编程高级技巧:深入理解代码生成与动态行为
人工智能·python·深度学习·机器学习
第一程序员13 分钟前
Python元编程:非科班转码者的入门指南
python·github