最近在看些c#的**,發現很多是以前沒有接觸到了,只能上網查,把比較好的整理下來。
經常碰到同時需要對某個資料進行操作,或者對某個檔案進行讀寫操作,對於這些操作我們以前往往不能很好的進行處理,自從c#語言中引入了lock這個關鍵字,以上問題就比較容易予以解決了,下面就是一段簡單的**。
public class accesscontrol()
}}在做郵箱接收閘道器的時候遇到了以下的需求,要求為每乙個郵箱開啟乙個接收執行緒,從pop3伺服器上收取,然後將郵件存放到統一的ftp伺服器上,要求郵件按收接順充從1開始順充編號。
我實現的方法為,為每個郵箱new出例項,然後分別賦給pop3郵箱位址,使用者名稱,密碼等引數。這裡涉及到乙個編號同步的問題,因為每個接收郵件的執行緒都是自己執行,所以取得編號並且遞增這個動作是互斥的。
以乙個靜態變數表示編號如下
class emailinfo
那在當前執行緒取得這個步驟為
_currentnumber=++emailinfo.currentnumber;
雖然此為一句,但在計算機執行時卻分為多步,如下
emialinfo.currentnumber加1--emailinfo.currentnumber返回值給_currentnumber
,也許執行緒1執行了emailinfo.currentnumber加1 的操作,但還沒有取得返回值,此時執行緒2又執行了emailinfo.currentnumber加1的操作,然後又執行緒1,執行緒2取得了返回值就是一樣的,這樣就失去了按順序遞增的作用。
此時查詢了網上有關執行緒同步的方法,其實用lock語句鎖住遞增的那一段即可。而介紹的相關用法為
lock(this)
本以為這樣就可以成功,誰知道還是無效,反覆查詢才發現沒弄清楚lock的用法。因為網上所講的資料,舉的例子比較簡單,是直接new 出乙個對像,然後為對像的乙個函式建立了多個執行緒執行,所以它的同步只要lock住this即它自己就行了。因為此時只有乙個例項在運,而我是new 出了多個對像,lock住每個自己的例項所以當然無效。
所以自然想了乙個解決方法,就lock住相同的乙個例項就行了。因為我每個郵件接收執行緒的引數都是不同的,所以還是new出幾個實像,但lock的方法改為如下
先為emailinfo加乙個靜態變數
class emailinfo
然後lock改為
lock(emailinfo.syncroot)
即可實現想要的效果了。
C 多執行緒中 lock用法
本文介紹c lockkeyword,c 提供了乙個keywordlock,它能夠把一段 定義為相互排斥段 critical section 相互排斥段在乙個時刻內僅僅同意乙個執行緒進入執行,而其他執行緒必須等待。每個執行緒都有自己的資源,可是 區是共享的,即每個執行緒都能夠執行相同的函式。這可能帶來...
C 多執行緒Lock
一.為什麼要lock,lock了什麼?當我們使用 執行緒的時候,效率最高的方式當然是 非同步,即各個執行緒同時執行,其間不相互依賴和等待。但當不同的執行緒都需要訪問某個資源的時候,就需要 同步機制 了,也就是說當對同乙個資源進行讀寫的時候,我們要使該資源在同一時刻只能被乙個執行緒操作,以確保每個操作...
Java 多執行緒之Lock的用法
lock 為執行緒加鎖解鎖,因為多個執行緒在訪問同乙個資源時,乙個資源不能同時給兩個執行緒進行讀寫操作.所以使用執行緒同步的方式來對資源進行訪問限制.下面來看lock的用法 使用流程 1.建立reentrantlock物件,首先,這個reentrantlock類 重入鎖 是一種遞迴無阻塞的同步機制的...