在阅读ArrayList源码的过程中发现了底层在实现添加和删除元素的时候,都使用了System.arraycopy方法。
在阅读过System.arraycopy源码后,发现了C中的经典复制语句。
while(from
< end)
*(to++) = *(from++);
arraycopy 方法是一个本地方法。
在 OpenJDK 源码包中可以找到
openjdk6-src/hotspot/src/share/vm/prims/jvm.cpp 文件。
既然这样的话,一切都豁然开朗,为什么使用arraycopy方法,因为C在操作内存的效率远高于Java。
所以在许多优化文档中都能看见推荐使用arraycopy方法来批量处理数组。
本文探讨了ArrayList在添加和删除元素时使用System.arraycopy方法的原因。通过对System.arraycopy源码的分析,揭示了其底层实现原理,并指出由于C语言在内存操作上的高效性,使得arraycopy成为数组批量处理的推荐选择。
1379

被折叠的 条评论
为什么被折叠?



