當多個執行緒同時併發讀寫資料庫的時候會丟擲異常,這是比較典型的多執行緒併發同步所帶來的問題,因為集合在讀的過程中是不容許我們修改的,因此就需要引入鎖的概念,加上讀寫鎖就不會出現問題。
集合類通常不是執行緒安全的,多個閱讀器可以安全的讀取集合.但是對集合的任何修改都將為訪問集合的所有執行緒生成不明確的結果.使用以下任何方法都可以令集合類是執行緒安全的
(1) 使用synchronized 方法,則從該類派生包裝,並通過該包裝以獨佔方式訪問集合
(2) 如果該類沒有synchronized 方法,則從該類派生並使用syncroot屬性實現synchronized 方法.
(3) 在訪問該集合時對syncroot屬性使用鎖定機制
這一段時間在公司做多執行緒的東西比較多,所以把一些心得寫了下來,對關注這一塊的朋友有個提示作用.
大家可以看看以下**:
class program
arraylist arraylist = new arraylist();
public
void
t1fun()
}public
void
t2fun()
system.threading.thread.sleep(1000);}}
public
void
t3fun()
system.threading.thread.sleep(1000);}}
}
這個測試程式得簡單,大家一看就明白了你可以執行一下看看,程式一會就掛了,揭示異常:未處理的異常: system.argumentoutofrangeexception: 索引超出範圍。必須為非負值並小於集合大小。
這就是因為多執行緒中對共享的集合資源同步引起的
下面是改後的**:
class program
arraylist arraylist = new arraylist();
public
void
t1fun()
system.console.out.writeline("寫入");
system.threading.thread.sleep(1000);}}
public
void
t2fun()
}system.threading.thread.sleep(1000);}}
public
void
t3fun()
}system.threading.thread.sleep(1000);}}
}
C 多執行緒(二) 資料同步
資料同步是多執行緒程式設計中不可避免的話題,下面來 一下資料同步相關的知識點。互斥量 互斥量是一種可被鎖定的變數,互斥量一般有排他互斥量 共享互斥量以及迴圈互斥量。排他互斥量是一種只能被乙個執行緒訪問 鎖定 的互斥量,當乙個執行緒獲得排他互斥量的鎖後,其他執行緒只有在該互斥的鎖釋放後才能獲得這個互斥...
C 多執行緒同步
在開發中經常會遇到執行緒的例子,如果某個後台操作比較費時間,我們就可以啟動乙個執行緒去執行那個費時的操作,同時程式繼續執行。在某些情況下可能會出現多個執行緒的同步協同的問題,下面的例子就展示了在兩個執行緒之間如何協同工作。這個程式的思路是共同做一件事情 從乙個arraylist中刪除元素 如果執行完...
C 多執行緒 執行緒同步事件
1 事件 事件是核心物件,多用於執行緒間通訊,可以跨程序同步 2 事件使用 1 建立事件 handle createevent lpsecurity attribute slpeventattributes,安全控制,一般直接傳入null bool bmanualreset,確定事件是手動還是自動 ...