成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面試官:CopyOnWrite容器有了解過嗎?

開發 后端
本節主要給大家講一下CopyOnWrite容器。其實呢,它是程序設計中的一種優化策略,從字面意思講是寫入時復制的思想。

CopyOnWrite容器

本節主要給大家講一下CopyOnWrite容器。其實呢,它是程序設計中的一種優化策略,從字面意思講是寫入時復制的思想。

?什么意思呢?就是計算機在執行并發調用的時候,比如需要對某個數據進行修改,它不會直接修改原數據,而是將原數據復制出來進行修改。

再理解CopyOnWrite容器就好理解了,意思也是一樣的,講當前容器中的數據復制出來,即副本容器,對其進行修改,達到讀寫分離的目的,最后再講原容器的引用執行新的容器。

?這么設計的好處很明顯,讀操作不需要頻繁的加鎖,JAVA也給我們提供了比較好用的類opyOnWriteArrayList和CopyOnWriteArraySet, 本節主要針對opyOnWriteArrayList進行講解。

CopyOnWriteArrayList

好處與壞處

?CopyOnWriteArrayList經常被用到讀多寫少的場景,由于它不需要鎖等同步方案,在讀的場景下性能比較好。

但是它也有缺點,因為它的實現需要拷貝一份數據,所以如果數據量特別大的情況下,內存壓力會比較大,很容易引發FULL GC。另外,由于讀寫都是作用在新的容器上,在寫操作時,讀不會被阻塞,有時候會發生讀到老數據。

如何去使用?

public class CopyOnWriteArrayList<E>
implements List<E>, RandomAccess, Cloneable, java.io.Serializable {...}

它實現了List接口,所以使用上差不多。

public static void main(String[] args) {
CopyOnWriteArrayList<Integer> list = new CopyOnWriteArrayList<>();
list.add(1);
System.out.println(list.get(0));
}

很簡單,沒少要講的,我們重點看下它的實現。

源碼解析

我們先看下它的構造函數。

// 默認情況下
public CopyOnWriteArrayList() {
setArray(new Object[0]);
}
// 允許指定集合
public CopyOnWriteArrayList(Collection<? extends E> c) {
Object[] elements;
if (c.getClass() == CopyOnWriteArrayList.class)
elements = ((CopyOnWriteArrayList<?>)c).getArray();
else {
elements = c.toArray();
if (c.getClass() != java.util.ArrayList.class)
elements = Arrays.copyOf(elements, elements.length, Object[].class);
}
setArray(elements);
}
// 包含給定的副本元素
public CopyOnWriteArrayList(E[] toCopyIn) {
setArray(Arrays.copyOf(toCopyIn, toCopyIn.length, Object[].class));
}

下面看下 add()方法。

public boolean add(E e) {
// 獲取鎖
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();
}
}
final void setArray(Object[] a) {
array = a;
}

我們可以看到在寫的過程中,是需要加鎖的, 再看下 get()方法。

public E get(int index) {
return get(getArray(), index);
}
private E get(Object[] a, int index) {
return (E) a[index];
}

可以看出此過程并沒有加鎖,所以從源碼看CopyOnWriteArrayList適合讀多寫少的場景。

結束語

有興趣的同學可以繼續研究一下它的源碼,相對來講不難.大家也可以舉一反三,試著通過CopyOnWrite機制寫一個CopyOnWriteMap,可以參考CopyOnWriteArrayList實現。

責任編輯:姜華 來源: 今日頭條
相關推薦

2022-07-26 08:40:42

Java并發工具類

2022-08-02 06:31:32

Java并發工具類

2022-06-10 13:56:42

Java

2022-06-30 08:14:05

Java阻塞隊列

2022-06-15 15:14:17

Java公平鎖非公平鎖

2022-06-08 13:54:23

指令重排Java

2022-06-09 11:20:44

volatile關鍵字

2022-06-30 14:31:57

Java阻塞隊列

2020-08-19 07:45:36

CopyOnwrite數據庫

2022-06-24 06:43:57

線程池線程復用

2022-07-18 14:18:26

Babel代碼面試

2021-04-12 21:34:29

Redis故障數據

2024-09-09 08:30:56

代碼

2022-06-02 09:29:55

線程組線程樹狀結構

2020-09-26 22:04:32

數據安全傳輸HTTPSHTTP 協議

2024-09-03 07:58:46

2020-10-08 14:15:15

Zookeeper

2023-02-20 08:08:48

限流算法計數器算法令牌桶算法

2025-03-26 01:25:00

MySQL優化事務

2024-03-07 17:21:12

HotSpotJVMHot Code
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 九九热这里只有精品在线观看 | 亚洲成人福利在线观看 | 国产成人一区二区三区电影 | 婷婷在线视频 | 欧美精品一区二区在线观看 | 99reav| 国产激情视频 | 国产美女特级嫩嫩嫩bbb片 | 国产精品久久久久久吹潮日韩动画 | 国产精品久久久久久久免费观看 | 亚洲日本成人 | 国产高清在线精品 | 成人av一区二区在线观看 | 欧美精品久久久久 | 成人免费大片黄在线播放 | 亚洲国产精品久久久久秋霞不卡 | 国产精品一区二区三区久久久 | 国产美女永久免费无遮挡 | 黑人中文字幕一区二区三区 | 永久免费视频 | 中文字幕在线观看视频网站 | 国产精品日韩一区 | 九九九色 | 国产成人高清成人av片在线看 | 欧美日韩国产在线观看 | 日韩在线观看网站 | 密室大逃脱第六季大神版在线观看 | 九色视频网 | 亚洲一区二区在线视频 | 精品视频在线免费观看 | 久久噜噜噜精品国产亚洲综合 | 91成人在线视频 | 亚洲成人一区 | 成人精品一区 | 久久精品综合网 | 午夜免费av | 91亚洲国产成人久久精品网站 | 97久久精品午夜一区二区 | 免费不卡视频 | www.yw193.com | 国产视频线观看永久免费 |