線程三線程安全

線程三線程安全
對於多線程的系統來說,如果不加以限制的話,會造成數據安全等問題,對於數據安全問題會有如下問題:
1、讀取髒數據 在讀取數據的時候,數據被修改了,而程序讀取的是修改過的或者沒有修改過的,反正不是自己期望讀取的數據的值。
2、數據不一致 在使用多線程進行數據處理的時候,最終得出來的數據每一次執行都不一樣。
3、數據錯亂 在數據的打印或者數組中,會造成數據的順序錯亂,對於關係可能會錯亂。
……
對於數據的安全性,java提供了一些解決的方法:
1、使用synchronized同步關鍵字
2、使用volatile關鍵字
3、使用原子類型:原子就是要麼全部成功,要麼全部失敗
(1)AtomicInteger整型原子類型
方法講解:
incrementAndGet();先自增在返回
decrementAndGet();先自減在返回
getAndIncrement();先返回在自增
getAndDecrement();先返回在自減
addAndGet(num);先加num在返回
getAndAdd(num);先返回在加num
(2)AtomicBoolean布爾類型的原子類型
getAndSet(Boolean b);先獲取在設置b值
(3)AtomicLong長類型的原子類型
incrementAndGet();先自增在返回
decrementAndGet();先自減在返回
getAndIncrement();先返回在自增
getAndDecrement();先返回在自減
addAndGet(num);先加num在返回
getAndAdd(num);先返回在加num
(4)AtomicIntegerArray 原子類型的整型數組
(5)AtomicLongArray 原子類型的長整型數組
原子數組操作:
set(seat,value);設置值
getAndAdd(seat, value);將seat值返回在加上value
getAndIncrement(seat);將seat值返回在自增1
4、線程安全的容器ConcurrentMap,ConcurrentHashMap等等。
……
在考慮線程的數據安全性後,還要考慮系統是否會造成死鎖的,飢餓等問題。
死鎖:就是在兩種以上不同的線程中,同時都佔用了一個資源,但是還差一個資源就可以完成任務,但是差的那個已經被別的線程佔有,又不想釋放自己佔有的資源,這樣,線程一直在等待資源,造成線程死鎖。
飢餓:就是在考慮的線程優先級的時候,低優先級的線程一直不能得到執行完成而造成的現象稱爲飢餓。
簡單代碼:
AtomicIntegerArray aia = new AtomicIntegerArray(10);
for(int i=0;i<10;i++) {
aia.set(i, i+1);
}
aia.getAndAdd(9, 10);
aia.getAndIncrement(8);
for(int i=0; i<10;i++) {
System.out.println(aia.get(i));
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章