• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            tqsheng

            go.....
            隨筆 - 366, 文章 - 18, 評論 - 101, 引用 - 0
            數據加載中……

            cpu 親和力

              與“soft affinity”相對的是“hard affiinty”(硬相關),使用它可以控制哪個CPU運行哪些線程。

              在系統引導的時候,系統決定該計算機中有幾個CPU可以被使用。在應用程序中,可以呼叫GetSystemInfo函數來取得CPU的數量。

              一般地,線程可以運行在任何一個CPU上,當然,你可以使用Windows自帶的“soft affinity”機制,讓Windows自動分配CPU給一個線程。

              或許,你更希望能夠對分配給線程的CPU有一些限制,使用“hard affinity”機制。

              SetProcessAffinityMask函數限制一個特定的進程只能運行在CPU的一個子集上。

             

            BOOL SetProcessAffinityMask(
               HANDLE hProcess,
               DWORD_PTR dwProcessAffinityMask);

             

              該函數得第一個參數指明了要被限制的進程,第二個參數是一個“位屏蔽”數據,里面的每個位表示一個CPU代號(從0開始標號),比如0x00000001表示選中CPU 0,也就是“該進程中的線程”只能運行在CPU 0上了;0x00000005表示同時選中CPU 0和CPU 2。

              一個進程中的子進程可以繼承該進程的相關性,也可以使用作業內核對象對某些進程限制在要求的一組CPU上執行。

             

              可以調用GetProcessAffinityMask函數來取得一個進程相關性屏蔽信息。

             

            BOOL GetProcessAffinityMask(
               HANDLE hProcess,
               PDWORD_PTR pdwProcessAffinityMask,
               PDWORD_PTR pdwSystemAffinityMask);

              該函數通過第二個參數返回指定進程的CPU的相關性信息,同時可以通過第三個參數返回系統相關性信息。系統相關性指明系統的哪些CPU可以處理線程,進程的相關性始終是系統相關性的子集。

             

              以上討論的是如何把一個進程中的所有線程限制在一組CPU上。有的時候想要把進程的一個具體線程限制在一組CPU上。

              SetThreadAffinityMask函數可以限制某一個線程只能運行在一組CPU上。

            DWORD_PTR SetThreadAffinityMask(
               HANDLE hThread,
               DWORD_PTR dwThreadAffinityMask);

             

              該函數的第二個參數的意義和SetProcessAffinityMask函數中的第二個參數相同。也必須指明了一個正確的CPU子集,限制指定的線程只能運行在這個CPU子集上。該函數返回原來的線程的相關信息。

              比如,現在有4個線程和4個可用的CPU,你想讓線程1獨占CPU 0,讓其他3個線程只能運行在CPU 1、CPU 2、CPU 3上,可以如下編碼:

            SetThreadAffinityMask(hThread0, 0x00000001);
            SetThreadAffinityMask(hThread1, 0x0000000E);
            SetThreadAffinityMask(hThread2, 0x0000000E);
            SetThreadAffinityMask(hThread3, 0x0000000E);

              使用“hard affinity”機制來強行限制一個線程只能運行在一組CPU上往往是不當的。這樣會降低CPU的利用率。

              可用將一個理想的CPU分配一個線程。SetThreadIdealProcessor函數可用做到這一點:

            DWORD SetThreadIdealProcessor(
               HANDLE hThread,
               DWORD dwIdealProcessor);

              該函數的第二個參數不是位屏蔽數據,而是一個0~31(32位系統)或0~63(64位系統)的整數。該數據指明首選的CPU。也可以傳遞MAXIMUM_PROCESSORS表明當前沒有理想的CPU。

             

              可以在一個程序的開始階段處理相關性,代碼類似如下的代碼:

            // 加載一個EXE文件映像
            PLOADED_IMAGE pLoadedImage = ImageLoad(szExeName, NULL);


            // 取得剛才加載的EXE文件的配置信息

            IMAGE_LOAD_CONFIG_DIRECTORY ilcd;
            GetImageConfigInformation(pLoadedImage, &ilcd);

            // 更改進程親掾性

            ilcd.ProcessAffinityMask = 0x00000003; // I desire CPUs 0 and 1

            // 保存新的加載信息(包含剛才設置的親掾性)

            SetImageConfigInformation(pLoadedImage, &ilcd);
            ImageUnload(pLoadedImage);     // 從內存卸載映像

            posted on 2012-09-19 23:19 tqsheng 閱讀(491) 評論(0)  編輯 收藏 引用

            久久久久久久91精品免费观看| 久久精品国产91久久麻豆自制| 无码人妻久久一区二区三区免费丨| 欧美综合天天夜夜久久| 中文精品久久久久国产网址| 久久久久国产一区二区 | 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 久久夜色精品国产噜噜亚洲a| 色悠久久久久久久综合网 | .精品久久久麻豆国产精品| 51久久夜色精品国产| 久久婷婷国产剧情内射白浆| 久久精品99久久香蕉国产色戒| 国产精品伦理久久久久久| 国内精品伊人久久久久777| 国产午夜电影久久| av无码久久久久久不卡网站| 久久精品国产欧美日韩| 久久成人国产精品| 久久福利资源国产精品999| 国产精品青草久久久久婷婷| 久久精品国产乱子伦| 久久精品一区二区影院 | 日韩久久久久久中文人妻| 婷婷综合久久狠狠色99h| 久久精品国产色蜜蜜麻豆| 久久久久无码精品国产app| 国产精品岛国久久久久| 五月丁香综合激情六月久久| 伊人久久一区二区三区无码| 久久久久综合中文字幕| 久久久精品日本一区二区三区| 久久99国产精品久久| 波多野结衣中文字幕久久| 亚洲国产另类久久久精品黑人| 久久精品成人欧美大片| 伊人久久成人成综合网222| 亚洲精品国产第一综合99久久| 亚洲v国产v天堂a无码久久| 伊人久久精品影院| 久久狠狠爱亚洲综合影院|