一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

C#中的lock關鍵字

  前幾天與同事激烈討論了一下,有一點收獲,記錄起來。

  首先給出MSDN的定義:

  lock 關鍵字可以用來確保代碼塊完成運行,而不會被其他線程中斷。這是通過在代碼塊運行期間為給定對象獲取互斥鎖來實現的。

  先來看看執行過程,代碼示例如下:

  假設線程A先執行,線程B稍微慢一點。線程A執行到lock語句,判斷obj是否已申請了互斥鎖,判斷依據是逐個與已存在的鎖進行object.ReferenceEquals比較(此處未加證實),如果不存在,則申請一個新的互斥鎖,這時線程A進入lock里面了。

  這時假設線程B啟動了,而線程A還未執行完lock里面的代碼。線程B執行到lock語句,檢查到obj已經申請了互斥鎖,于是等待;直到線程A執行完畢,釋放互斥鎖,線程B才能申請新的互斥鎖并執行lock里面的代碼。

  接下來說一些該lock什么對象。

  為什么不能lock值類型,比如lock(1)呢?lock本質上Monitor.Enter,Monitor.Enter會使值類型裝箱,每次lock的是裝箱后的對象。lock其實是類似編譯器的語法糖,因此編譯器直接限制住不能lock值類型。退一萬步說,就算能編譯器允許你lock(1),但是object.ReferenceEquals(1,1)始終返回false(因為每次裝箱后都是不同對象),也就是說每次都會判斷成未申請互斥鎖,這樣在同一時間,別的線程照樣能夠訪問里面的代碼,達不到同步的效果。同理lock((object)1)也不行。

  那么lock("xxx")字符串呢?MSDN上的原話是:

  鎖定字符串尤其危險,因為字符串被公共語言運行庫 (CLR)“暫留”。 這意味著整個程序中任何給定字符串都只有一個實例,就是這同一個對象表示了所有運行的應用程序域的所有線程中的該文本。因此,只要在應用程序進程中的任何位置處具有相同內容的字符串上放置了鎖,就將鎖定應用程序中該字符串的所有實例。通常,最好避免鎖定 public 類型或鎖定不受應用程序控制的對象實例。例如,如果該實例可以被公開訪問,則 lock(this) 可能會有問題,因為不受控制的代碼也可能會鎖定該對象。這可能導致死鎖,即兩個或更多個線程等待釋放同一對象。出于同樣的原因,鎖定公共數據類型(相比于對象)也可能導致問題。而且lock(this)只對當前對象有效,如果多個對象之間就達不到同步的效果。

  lock(typeof(Class))與鎖定字符串一樣,范圍太廣了。某些系統類提供專門用于鎖定的成員。例如,Array 類型提供 SyncRoot。許多集合類型也提供 SyncRoot。而自定義類推薦用私有的只讀靜態對象,比如:private static readonly object obj = new object();為什么要設置成只讀的呢?這時因為如果在lock代碼段中改變obj的值,其它線程就暢通無阻了,因為互斥鎖的對象變了,object.ReferenceEquals必然返回false。

NET技術C#中的lock關鍵字,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 一级做a级爰片性色毛片视频 | 2021国产麻豆剧传媒精品网站 | 日本三区 | sihu国产午夜精品一区二区三区 | 国产免费69成人精品视频 | 一级做a爰片久久毛片人呢 一级做a爰片久久毛片图片 | 五月婷婷久 | 国产精品久久久亚洲 | 色婷婷综合久久久中文字幕 | 国产精品免费αv视频 | 黄视频入口 | 在线观看成人免费视频 | 精品久久久久久中文字幕 | 久久婷婷色一区二区三区 | 亚洲五月花丁香花社区 | 91刘亦菲精品福利在线 | 日韩 亚洲 中文 图片 小说 | 亚洲资源在线 | 国产91精品高跟丝袜在线 | 欧美日韩国产码高清综合人成 | 国产精品国色综合久久 | 91专区在线观看 | 国产一区二区高清在线 | 性做久久久久久久久男女 | 一本久久a久久精品亚洲 | 日韩视频免费一区二区三区 | 欧美亚洲图片小说 | 国产日韩精品欧美在线ccc | 国产美女免费观看 | 国产一起色一起爱 | 婷婷综合 在线 | 91麻豆精品一二三区在线 | 国产美女一级片 | 9797在线看片亚洲精品 | 久久免费特黄毛片 | 久久91精品国产91久久跳舞 | 综合久久伊人 | 欧美另类xxx精品人妖 | 久久国产精品1区2区3区网页 | 在线观看视频91 | 九九操视频 |