• <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>
            We do not always find visible happiness in proportion to visible virtue

            夢幻白樺林

            SHARE

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              14 Posts :: 58 Stories :: 62 Comments :: 0 Trackbacks

            公告

            常用鏈接

            留言簿(5)

            搜索

            •  

            最新隨筆

            最新評論

            閱讀排行榜

            Critical Sections 并不是核心對象。因此沒有 handle 這樣的東西。它和核心對象不同,它存在于進程的內(nèi)存空間中。你不需要使用想“ Create ”這樣的 API 函數(shù)獲得一個 critical section handle 。你應該做的是將一個類型為 CRITICAL_SECTION 的局部變量初始化,方法是調(diào)用 InitializeCriticalSection():

            The InitializeCriticalSection function initializes a critical section object.

            VOID InitializeCriticalSection(

            ??? LPCRITICAL_SECTION lpCriticalSection ?????????????? // address of critical section object?

            ?? );?????????

            ?Parameters

            lpCriticalSection

            Points to the critical section object.

            Return Values

            This function does not return a value.


            當你用畢
            critical section 時,你必須調(diào)用 DeleteCriticalSection() 清除它。這個函數(shù)并沒有“釋放對象”的意義在里頭,不要把它和 C++ delete 運算符混淆了。

            The DeleteCriticalSection function releases all resources used by an unowned critical section object.

            VOID DeleteCriticalSection(

            ??? LPCRITICAL_SECTION lpCriticalSection ?????????????? // pointer to critical section object?

            ?? );?????????

            Parameters

            lpCriticalSection

            Points to the critical section object.

            Return Values

            This function does not return a value.


            一旦
            critical section 被初始化,每一個線程就可以進入其中——只要他通過了 EnterCriticalSection() 這一關(guān):

            The EnterCriticalSection function waits for ownership of the specified critical section object. The function returns when the calling thread is granted ownership.

            VOID EnterCriticalSection(

            ??? LPCRITICAL_SECTION lpCriticalSection ?????????????? // pointer to critical section object?

            ?? );?????????

            Parameters

            lpCriticalSection

            Points to the critical section object.

            Return Values

            This function does not return a value.


            當線程準備好離開
            critical section 的時候,他必須調(diào)用 LeaveCriticalSection():

            The LeaveCriticalSection function releases ownership of the specified critical section object.

            VOID LeaveCriticalSection(

            ??? LPCRITICAL_SECTION lpCriticalSection ?????????????? // address of critical section object?

            ?? );?????????

            Parameters

            lpCriticalSection

            Points to the critical section object.

            Return Values

            This function does not return a value.


            下面是一個很簡單的使用例子,只是為了演示如何使用,沒有其它目的:

            #include <stdio.h>

            #include <windows.h>

            const int numThreads = 3;

            //?¨ò?ò???critical section±?á?

            CRITICAL_SECTION gCS;

            ?

            DWORD WINAPI helloFunc(LPVOID pArg)

            {

            ?????? //??è?critical section

            ?????? EnterCriticalSection(&gCS);

            ??????

            ?????? int num = (int) pArg;

            ?????? printf("Hello Thread %d\n", num);

            ?

            ?????? //??3ìó?±?£???μ?μ÷ó?′?oˉê?à??acritical section?££¨Enter**ó?Leave**μ?ê?á?òa????£?

            ?????? LeaveCriticalSection(&gCS);

            ?????? return 0;

            }

            ?

            int main()

            {?????

            ?????? //3?ê??ˉcritical section

            ?????? InitializeCriticalSection(&gCS);

            ?????? HANDLE hThread[numThreads];

            ?????? DWORD begin = GetTickCount();

            ?

            ?????? for (int i = 0; i < numThreads; i++)

            ?????? {

            ????????????? hThread[i] = CreateThread(NULL, 0, helloFunc, (LPVOID)i, 0, NULL);

            ?????? }

            ?

            ?????? WaitForMultipleObjects(numThreads, hThread, TRUE, INFINITE);

            ?????? DWORD elapse = GetTickCount() - begin;

            ?????? printf("elapse time: %d\n", elapse);

            ?

            ?????? //?ùó???3ì?′??íê±?oó£?deleteμ?critical section

            ?????? DeleteCriticalSection(&gCS);

            ?????? return 0;

            }

            ?

            ?

            Google


            小熊 2007-03-30 14:58 發(fā)表評論

            文章來源:http://m.shnenglu.com/jacky2019/archive/2007/03/30/20938.html
            posted on 2007-03-31 23:03 colys 閱讀(152) 評論(0)  編輯 收藏 引用

            亚洲国产二区三区久久| 伊人久久大香线焦AV综合影院| 久久人人爽人人爽人人AV| 久久99久久99小草精品免视看| 精品久久久久久无码人妻蜜桃| 久久久久久久久久久精品尤物| 久久免费小视频| 亚洲人成精品久久久久| 国产A级毛片久久久精品毛片| 久久久久久午夜精品| 久久综合九色综合久99| 久久久久久精品免费免费自慰| 伊人丁香狠狠色综合久久| 亚洲女久久久噜噜噜熟女| 久久嫩草影院免费看夜色| 国产99精品久久| 久久亚洲日韩精品一区二区三区| 久久久久久A亚洲欧洲AV冫 | 99久久国产亚洲高清观看2024| 午夜精品久久久久成人| 精品久久久久中文字| 一本久久久久久久| 99久久精品午夜一区二区 | 99久久婷婷国产综合亚洲| 欧美日韩久久中文字幕| 亚洲国产精品狼友中文久久久 | 久久99精品久久久久久齐齐| 热re99久久精品国产99热| 久久国产精品久久| 国产精品美女久久久久久2018| 久久亚洲精品国产亚洲老地址| 性高朝久久久久久久久久| 久久久国产精品| 色偷偷88欧美精品久久久| 色婷婷噜噜久久国产精品12p | 一本久久免费视频| 久久久久久久波多野结衣高潮| 久久无码国产专区精品| 色婷婷综合久久久中文字幕| 亚洲精品乱码久久久久久中文字幕| 久久人人爽人人爽人人片AV不|