日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
C#中Finally的一個不太常見的用法

最近在看.net BCL 傳送門 的源碼. 在

System.Collections.Concurrent.ConcurrentQueue

中看到一段有意思的代碼.注意這段代碼是寫在ConcurrentQueue這個用于并發(fā)中的隊列. 注意,這是一個無鎖隊列的實現(xiàn).

 
 
  1. try 
  2.  { }  
  3.  finally 
  4.  {  
  5.      newhigh = Interlocked.Increment(ref m_high);  
  6.      if (newhigh <= SEGMENT_SIZE - 1)  
  7.      {  
  8.          m_array[newhigh] = value;  
  9.          m_state[newhigh].m_value = true;  
  10.      }  
  11.      if (newhigh == SEGMENT_SIZE - 1)  
  12.      {  
  13.          Grow();  
  14.      }  
  15.  } 

有意思嗎?代碼中使用了一個空的Try代碼塊.然后把代碼全都寫在了Finally塊.這么做的目地何在呢?

這其實是一個小的技巧:放在Finally中的代碼可以防止執(zhí)行線程在執(zhí)行過程中被另一個線程用調(diào)用了Thread.Abort()或Thread. Interrupt()打斷.從而保證這段代碼執(zhí)行的完整性。

舉個例子: 如果不將上面代碼放到Finally中運行.假如正好有一個線程A執(zhí)行到 m_array[newhigh] = value;而另外一個線程B調(diào)用了線程A的Thread.Abort() 那么m_array[newhigh] = value; 以后的代碼可能沒有機會得到執(zhí)行.那么將引起ConcurrentQueue的不完整。

而放到Finally中的代碼,即使線程B在線程A執(zhí)行時調(diào)用了Thread.Abort()或Thread. Interrupt()方法時也能保證Finally塊中的代碼被完整的執(zhí)行。

事實上,這個特性是在.net framework2.0中引入的.在.net 1.1時Finally沒有這個作用.另外 Tread.Abort有可能打斷線程內(nèi)的靜態(tài)構(gòu)構(gòu)函數(shù)執(zhí)行。

另外我認為同樣的功能也可以用這個Thread.BeginCriticalRegion 和Thread.EndCriticalRegion(); 來實現(xiàn)。

原文鏈接:http://www.cnblogs.com/listhome/p/3664300.html


網(wǎng)頁題目:C#中Finally的一個不太常見的用法
文章分享:http://www.5511xx.com/article/djggcic.html