新聞中心
Java 5之后提供優(yōu)秀的并發(fā)庫util.concurrent,.NET中缺乏類似的功能。由于硬件體系發(fā)生了變化,多核時(shí)代來臨,.NET中缺乏并發(fā)類庫顯然不合時(shí)宜。緩解這一矛盾的其中一個(gè)辦法就是把Java的util.concurrent移植到C#.

成都創(chuàng)新互聯(lián)公司專注于蜀山企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站,商城網(wǎng)站建設(shè)。蜀山網(wǎng)站建設(shè)公司,為蜀山等地區(qū)提供建站服務(wù)。全流程按需設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
Java中的util.concurrent包中提供了一個(gè)類LockSupport,util.concurrent包很多關(guān)鍵實(shí)現(xiàn)需要調(diào)用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);
- }
當(dāng)一個(gè)線程調(diào)用LockSupport.park之后,線程就會(huì)停下載,類似于Object.wait,或者.NET中的System.Threading.Monitor.Wait.但問題是Java中的 Object.wait和.NET中的Monitor.wait,都需要一個(gè)waitObject,這個(gè)問題曾經(jīng)困擾我,為此翻了一遍JDK 6實(shí)現(xiàn)源碼,到最后發(fā)現(xiàn)的解決辦法卻是很簡單,也無需了解JDK的底層實(shí)現(xiàn)源碼。
以下是引用片段:
- publicclassLockSupport
- {
- privatestaticLocalDataStoreSlotslot=Thread.GetNamedDataSlot("LockSupport.Park");
- publicstaticvoidPark(Objectblocker)
- {
- ThreadThreadthread=Thread.CurrentThread;
- Thread.SetData(slot,blocker);
- lock(thread)
- {
- Monitor.Wait(thread);
- }
- }
- publicstaticvoidUnpark(Threadthread)
- {
- if(thread==null)return;
- lock(thread)
- {
- Monitor.Pulse(thread);
- }
- }
- }
以上介紹util.concurrent移植到C#
當(dāng)前文章:util.concurrent移植到C#
網(wǎng)頁路徑:http://m.fisionsoft.com.cn/article/cdgicps.html


咨詢
建站咨詢
