ArrayList查询快,因其底层基于连续内存的数组,支持下标直接访问,时间复杂度O(1);相比LinkedList需遍历指针且节点分散,它还具备缓存友好性和更少的对象引用开销。
ArrayList查询快,核心在于它底层用的是数组,支持通过下标直接访问元素,时间复杂度是 O(1)。
ArrayList内部封装了一个Object[]数组,元素在内存中是连续存放的。只要知道起始地址和每个元素大小,就能通过“首地址 + 下标 × 单个元素偏移量”一步算出目标元素位置,无需遍历。
CPU访问内存时会预加载相邻数据块(cache line)。ArrayList元素紧挨着,一次预取可能覆盖后续几次get操作所需的数据,减少实际内存访问次数。
ArrayList里存的是元素的引用(或基本类型包装后的引用),get操作只需解引用一次;LinkedList每个节点还要多一层Node对象封装,包含item、next、prev三个字段,访问item前得先拿到Node实例。
基本上就这些——不是玄学优化,而是数组结构天然带来的定位能力+硬件层面的配合。当然,增删慢是它的另一
面,但查得快这点,确实靠得住。