• <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>

            我的玻璃盒子

            (轉(zhuǎn)帖)Windows同步API (二)—— Event

            原文鏈接:http://www.shnenglu.com/wangjt/archive/2008/02/01/42312.html

              Event即事件是一種用于進行線程/進程間同步的對象,事件有置位和復(fù)位兩種狀態(tài),當(dāng)線程通過waiting functions等待Event對象置位時該線程將進入阻塞狀態(tài),當(dāng)該Event對象被置位或等待超時后,等待的線程將恢復(fù)執(zhí)行。Event可以用在一個線程要等待其它線程時。
            可以使用CreateEvent創(chuàng)建Event對象
            HANDLE WINAPI CreateEvent(
                LPSECURITY_ATTRIBUTES lpEventAttributes,
                BOOL bManualReset,
                BOOL bInitialState,
                LPCTSTR lpName
            );
            lpEventAttributes用于指定Event對象的安全屬性,包括句柄是否可被子進程繼承和對象的安全描述符。可設(shè)置NULL取默認安全屬性。
            bManualReset表明Event對象是否需要手動復(fù)位。如果該參數(shù)為TRUE,則Event對象需要通過ResetEvent函數(shù)手動復(fù)位。如果該參數(shù)為FALSE,則Event被創(chuàng)建為自動復(fù)位的Event,任何等待的線程被恢復(fù)執(zhí)行后,該Event將被系統(tǒng)自動復(fù)位。打個比方,如果有10個線程在等待一個Event,這時將Event置位,如果這是個手動復(fù)位Event,那么這10個線程將被依次喚醒直到通過ResetEvent調(diào)用將該Event復(fù)位;如果Event為自動復(fù)位Event,那么10個線程中的第一個被喚醒后Event被自動復(fù)位,其它線程將繼續(xù)等待。
            bInitialState參數(shù)表明Event對象被創(chuàng)建后默認是否置位。
            lpName參數(shù)是Event的名字,可以為空表明將創(chuàng)建匿名Event。
            CreateEvent函數(shù)在調(diào)用成功后返回Event句柄。如果同名Event已經(jīng)存在,則返回這個已經(jīng)存在了的Event的句柄,此時調(diào)用GetLastError函數(shù)將返回 ERROR_ALREADY_EXISTS。
            還可以通過OpenEvent打開一個已經(jīng)創(chuàng)建的非匿名Event
            HANDLE WINAPI OpenEvent(
                DWORD dwDesiredAccess,
                BOOL bInheritHandle,
                LPCTSTR lpName
            );
            在創(chuàng)建或打開了Event對象之后,可以使用SetEvent和ResetEvent函數(shù)來置位或復(fù)位一個Event對象。
            BOOL WINAPI SetEvent(
                HANDLE hEvent
            );
            BOOL WINAPI ResetEvent(
                HANDLE hEvent
            );
            要等待一個或多個Event對象置位可以使用wait functions。
            簡單示例,一個線程不停讀取用戶輸入并放入message列表,另一個線程模擬將message發(fā)送出去,如果沒有消息,則發(fā)送線程處于阻塞狀態(tài)等待,一旦有消息錄入,輸入線程將event置位,發(fā)送線程即被激活并逐個發(fā)送消息。
            #include "stdafx.h"
            #include <windows.h>
            #include <tchar.h>
            #include <iostream>
            #include <list>
            #include <string>
            using namespace std;

            #ifdef _UNICODE
            typedef wstring tstring;
            #define tcout wcout
            #define tcin wcin
            #else
            typedef string tstring;
            #define tcout cout
            #define tcin cin
            #endif /* _UNICODE */

            typedef list<tstring> StringList;

            HANDLE hMutex = NULL;
            HANDLE hEvent = NULL;
            HANDLE hSendThread = NULL;
            StringList messages;

            bool isRunning;

            DWORD WINAPI SendThreadProc(LPVOID lpThreadParameter)
            {
            DWORD dw;
            while(isRunning)
            {
              dw = WaitForSingleObject(hEvent, INFINITE);
              if(dw != WAIT_OBJECT_0)
              {
               tcout << _T("Wait error.") << endl;
               return -1;
              }
              dw = WaitForSingleObject(hMutex, INFINITE);
              if(WAIT_OBJECT_0 != dw && WAIT_ABANDONED != dw)
              {
               tcout << _T("Wait error.") << endl;
               return -2;
              }

              StringList list(messages);
              messages.clear();

              ReleaseMutex(hMutex);

              for(StringList::iterator i = list.begin(); i != list.end(); i++)
              {
               Sleep(1000); //休眠1秒模擬發(fā)送所耗時間

               tcout << _T("/* Send Message:") << *i << _T(" */");
              }

            }

            return 0;
            }

            int _tmain(int argc, _TCHAR* argv[])
            {
            hMutex = CreateMutex(NULL, FALSE, NULL);
            hEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
            isRunning = true;

            hSendThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)SendThreadProc, NULL, 0, NULL);

            while(isRunning)
            {
              tstring s;
              tcin >> s;
              if(s == _T("quit"))
              {
               isRunning = true;
               break;
              }

              DWORD dw = WaitForSingleObject(hMutex, INFINITE);
              if(WAIT_OBJECT_0 != dw && WAIT_ABANDONED != dw)
              {
               tcout << _T("Wait error.") << endl;
               return -1;
              }
              messages.push_back(s);
              ReleaseMutex(hMutex);
              SetEvent(hEvent);
            }

            CloseHandle(hMutex);
            CloseHandle(hEvent);
            CloseHandle(hSendThread);

            return 0;

            }

            posted on 2008-02-03 10:44 深藍色系統(tǒng) 閱讀(575) 評論(0)  編輯 收藏 引用 所屬分類: Windows開發(fā)

            導(dǎo)航

            <2008年11月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            統(tǒng)計

            常用鏈接

            留言簿(75)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久青草国产精品一区| 欧美精品国产综合久久| 久久精品黄AA片一区二区三区| 欧美黑人激情性久久| 99久久er这里只有精品18| 亚洲国产精品久久久久| 欧美伊人久久大香线蕉综合69| 麻豆久久久9性大片| 精品国产乱码久久久久久人妻| 久久天堂AV综合合色蜜桃网 | 久久精品人妻一区二区三区| 久久婷婷色香五月综合激情| 成人综合伊人五月婷久久| 精品国产综合区久久久久久| 亚洲午夜久久久影院| 亚洲国产精品人久久| 国产成人无码精品久久久性色| 亚洲国产精品婷婷久久| 久久精品国产亚洲AV高清热| 合区精品久久久中文字幕一区| 97久久精品国产精品青草| 偷偷做久久久久网站| 国内精品欧美久久精品| 99久久国产综合精品麻豆| 香蕉久久夜色精品升级完成| 久久亚洲天堂| 久久99精品国产麻豆蜜芽| 久久国产热精品波多野结衣AV| 日本五月天婷久久网站| 久久精品亚洲欧美日韩久久| 日本精品久久久中文字幕| 99999久久久久久亚洲| 久久精品国产久精国产思思 | 狠狠色丁香婷婷久久综合五月| 久久久久亚洲AV无码专区桃色 | 久久e热在这里只有国产中文精品99| 97久久久久人妻精品专区| 精品久久8x国产免费观看| 色88久久久久高潮综合影院| 性色欲网站人妻丰满中文久久不卡| 综合人妻久久一区二区精品|