util.concurrent移植到C#

Java 5之后提供优秀的并发库util.concurrent,.NET中缺乏类似的功能。由于硬件体系发生了变化,多核时代来临,.NET中缺乏并发类库显然不合时宜。缓解这一矛盾的其中一个办法就是把Java的util.concurrent移植到C#.

Java中的util.concurrent包中提供了一个类LockSupport,util.concurrent包很多关键实现需要调用LockSupport.如果需要把Java的util.concurrent移植到C#中,LockSupport类的迁移是不可避免的问题。

在Java中,LockSupport类有如下方法:

以下是引用片段:

 
 
 
  1. public static void park(Object blocker) {   
  2. Thread t = Thread.currentThread();   
  3. setBlocker(t, blocker);   
  4. unsafe.park(false, 0L);   
  5. setBlocker(t, null);   

当一个线程调用LockSupport.park之后,线程就会停下载,类似于Object.wait,或者.NET中的System.Threading.Monitor.Wait.但问题是Java中的 Object.wait和.NET中的Monitor.wait,都需要一个waitObject,这个问题曾经困扰我,为此翻了一遍JDK 6实现源码,到最后发现的解决办法却是很简单,也无需了解JDK的底层实现源码。

以下是引用片段:

 
 
 
  1. publicclassLockSupport  
  2. {  
  3. privatestaticLocalDataStoreSlotslot=Thread.GetNamedDataSlot("LockSupport.Park");  
  4. publicstaticvoidPark(Objectblocker)  
  5. {  
  6. ThreadThreadthread=Thread.CurrentThread;  
  7. Thread.SetData(slot,blocker);  
  8. lock(thread)  
  9. {  
  10. Monitor.Wait(thread);  
  11. }  
  12. }  
  13. publicstaticvoidUnpark(Threadthread)  
  14. {  
  15. if(thread==null)return;  
  16. lock(thread)  
  17. {  
  18. Monitor.Pulse(thread);  
  19. }  
  20. }  

以上介绍util.concurrent移植到C#

【编辑推荐】

  1. 介绍Mono C#编译器
  2. C#运算符重载学习总结
  3. 概述C#语言的结构体
  4. C#遗传算法学习笔记
  5. 讨论C#分部方法
THE END