Java util.concurrent中LockSupport類在C#中的實現

來源:互聯網
上載者:User
java 5之後提供優秀的並發庫util.concurrent,.net中缺乏類似的功能。由於硬體體系發生了變化,多核時代來臨,.NET中缺乏並發類庫顯然不合時宜。其中一個辦法就是在往C#中移植java的util.concurrent。

java中的util.concurrent包中提供了一個類LockSupport,util.concurrent包很多關鍵實現需要調用LockSupport。如果需要把java的util.concurrent包遷移到C#中,LockSupport類的遷移是不可避免的問題。

在java中,LockSupport類有如下方法:public static void park(Object blocker) {
    Thread t = Thread.currentThread();
    setBlocker(t, blocker);
    unsafe.park(false, 0L);
    setBlocker(t, null);
}

當一個線程調用LockSupport.park之後,線程就會停下載,類似於Object.wait,或者.NET中的System.Threading.Monitor.Wait。但問題是java中的Object.wait和.NET中的Monitor.wait,都需要一個waitObject,這個問題曾經困擾我,為此翻了一遍JDK 6實現源碼,到最後發現的解決辦法卻是很簡單,也無需瞭解JDK的底層實現源碼。

public class LockSupport
{
    private static LocalDataStoreSlot slot = Thread.GetNamedDataSlot("LockSupport.Park");
   
    public static void Park(Object blocker)
    {
        Thread thread = Thread.CurrentThread;
        Thread.SetData(slot, blocker);
        lock (thread)
        {
            Monitor.Wait(thread);
        }
    }

    public static void Unpark(Thread thread)
    {
        if (thread == null) return;

        lock (thread)
        {
            Monitor.Pulse(thread);
        }
    }
}

其中的slot是可以不需要的,但是參考JDK util.concurrent的LockSupport代碼中看到,使用slot(java的ThreadLocal)可以方便跟蹤調試。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.