ArrayList 面试10连问

12 篇文章 0 订阅

**

【集合】ArrayList 10连问

**
List list = new ArrayList();
1问:当我们new了一个ArrayList,底层new了一个什么?new了一个数组

2问:什么类型的数组?object[]

3问 : 数组的长度是多大?10 ;数组长度默认是空, add 以后 底层创建了长度是10的Object[]数组

4问:数组的长度是10,我现在要放25, 为什么没有报【数组下标越界异常】 , 容量不够,有扩容机制

5问:扩容为原来的1.5倍, ArrayList每次扩容为原值的一半,hashmap每次扩容为原值的一倍; 10 第一次扩容原值一半是 15;

6问:第二次扩容是多少?第二次扩容是15+7.5=22.5 向上取整为22;第三次扩容为33

7问:有没有看过ArrayList底层源码? 有,扩容是怎么扩的? 底层用的是什么方法? 底层用的是Arrays.copyOf
elementData = Arrays.copyOf(elementData, size, Object[].class);

8问:ArrayList 是线程安全的还是线程不安全的? ArrayList是线程不安全的,你确定吗? 我确定

9问:请你写一个线程不安全的case,会报什么故障,怎么处理?
会报:java.util.ConcurrentModificationException【并发修改异常】
解决:使用juc的写时复制技术
List list = new CopyOnWriteArrayList();//写时复制【读写分离】
//解决方案一
//List list = new Vector();//Vector 不使用 JDK1.0 版本低
//解决方案二
//List list = Collections.synchronizedList(new ArrayList<>());
//解决方案三
List list = new CopyOnWriteArrayList();//写时复制
NotSaftDemo

 //方式一:使用lambda表达式
 for(i=1,i<=30,i++)

 {
     new Thread(() -> {
         list.add(UUID.randomUUID().toString().substring(0, 8));
         sout(list);
     }, String.valueOf(i)).start();
 }

 //方式二:实现Runnable接口
 for(i=1,i<=30,i++)

 {
     new Thread(new Runnable() {
         @Override
         public void run() {
             list.add(UUID.randomUUID().toString().substring(0, 8));
             sout(list);
         }
     }, String.valueOf(i)).start();
 }

10问:你了解什么是写时复制技术?谈谈你的理解?
ArrayList 举例子:签到名单

笔记

  • 写时复制
    CopyOnWrite容器即写时复制的容器。往一个容器添加元素的时候,不直接往当前容器Object[]添加,而是先将当前容器Object[]进行Copy,
    复制出一个新的容器Object[] newElements,然后新的容器Object[] newElements里添加元素,添加完元素之后,
    再将原容器的引用指向新的容器 setArray(newElements);。这样做的好处是可以对CopyOnWrite容器进行并发的读,
    而不需要加锁,因为当前容器不会添加任何元素。所以CopyOnWrite容器也是一种读写分离的思想,读和写不同的容器
{
final ReentrantLock lock = this.lock;
lock.lock();

try
{
Object[] elements = getArray();
int len = elements.length;
Object[] newElements = Arrays.copyOf(elements, len + 1);
newElements[len] = e;
setArray(newElements);
return true;
}
finally {
lock.unlock();
}
}
  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT二叔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值