• <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>
            春暖花開
            雪化了,花開了,春天來了
            posts - 149,comments - 125,trackbacks - 0
            進程的互斥運行
            http://bbs.onlycpp.net/viewthread.php?tid=540&extra=page%3D1

              正常情況下,一個進程的運行一般是不會影響到其他正在運行的進程的。但是對于某些有特殊要求的如以獨占方式使用串行口等硬件設備的程序就要求在其進程運行期間不允許其他試圖使用此端口設備的程序運行的,而且此類程序通常也不允許運行同一個程序的多個實例。這就引出了進程互斥的問題。

              實現進程互斥的核心思想比較簡單:進程在啟動時首先檢查當前系統是否已經存在有此進程的實例,如果沒有,進程將成功創建并設置標識實例已經存在的標記。此后再創建進程時將會通過該標記而知曉其實例已經存在,從而保證進程在系統中只能存在一個實例。具體可以采取內存映射文件、有名事件量、有名互斥量以及全局共享變量等多種方法來實現。下面就分別對其中具有代表性的有名互斥量和全局共享變量這兩種方法進行介紹:
            // 創建互斥量
            HANDLE m_hMutex = CreateMutex(NULL, FALSE, "Sample07");
            // 檢查錯誤代碼
            if (GetLastError() == ERROR_ALREADY_EXISTS) {
             // 如果已有互斥量存在則釋放句柄并復位互斥量
             CloseHandle(m_hMutex);
             m_hMutex = NULL;
             // 程序退出
             return FALSE;
            }

              上面這段代碼演示了有名互斥量在進程互斥中的用法。代碼的核心是CreateMutex()對有名互斥量的創建。CreateMutex()函數可用來創建一個有名或無名的互斥量對象,其函數原型為:
            HANDLE CreateMutex(
             LPSECURITY_ATTRIBUTES lpMutexAttributes, // 指向安全屬性的指針
             BOOL bInitialOwner, // 初始化互斥對象的所有者
             LPCTSTR lpName // 指向互斥對象名的指針
            );

              如果函數成功執行,將返回一個互斥量對象的句柄。如果在CreateMutex()執行前已經存在有相同名字的互斥量,函數將返回這個已經存在互斥量的句柄,并且可以通過GetLastError()得到錯誤代碼ERROR_ALREADY_EXIST。可見,通過對錯誤代碼ERROR_ALREADY_EXIST的檢測可以實現CreateMutex()對進程的互斥。
                    建立互斥體,用來同步。如果一個線程獲取了互斥體,則要獲取該互斥體的第二個線程將被掛起,直到第一個線程釋放該互斥體。

            參數
            lpMutexAttributes
            指向一個SECURITY_ATTRIBUTES結構的指針,這個結構決定互斥體句柄是否被子進程繼承。     
            bInitialOwner
            布爾類型,決定互斥體的創建者是否為擁有者
            lpName
            指向互斥體名字字符串的指針?;コ怏w可以有名字。
            互斥體的好處是可以在進程間共享
            心得體會:
                CreateMutex() 用于有獨占要求的程序 (在其進程運行期間不允許其他使用此端口設備的程序運行,或不允許同名程序運行)。如有同名程序運行,則通過 GetLastError()得到錯誤代碼 ERROR_ALREADY_EXIST。

            剛才又執行了下得出的結果(程序名samp)
                   一般情況下:一進入調試階段,進程管理器中就出現了samp進程,執行到CreateMutex時返回進程句柄,執行到if(GetLastError() == ERROR_ALREADY_EXISTS ) 進行判斷時,跳過不執行if中的內容,所以表示沒有互斥。
                   調試之前先運行debug中的samp.exe再調試:一進入調試階段,進程管理器中就出現了兩個samp進程,執行到CreateMutex時返回進程句柄,執行到if(GetLastError() == ERROR_ALREADY_EXISTS ) 進行判斷時,執行if中的內容,表示有互斥。
            posted on 2008-12-26 18:46 Sandy 閱讀(656) 評論(0)  編輯 收藏 引用 所屬分類: C++
            99蜜桃臀久久久欧美精品网站| 欧美日韩中文字幕久久伊人| 久久久久国产亚洲AV麻豆| 久久婷婷五月综合国产尤物app| 2021国产精品久久精品| 香蕉久久夜色精品国产尤物| 久久久无码精品亚洲日韩软件| 久久夜色精品国产| 亚洲国产综合久久天堂 | 亚洲?V乱码久久精品蜜桃| 精品一久久香蕉国产线看播放| 久久精品成人欧美大片| 久久男人AV资源网站| 97视频久久久| 国产亚洲精品自在久久| 99久久精品免费看国产| 亚洲性久久久影院| 久久青青草原精品国产| 99久久国产免费福利| 久久夜色精品国产| 久久人人爽人人爽人人片av高请| 久久国产精品成人影院| 国产精品女同一区二区久久| 色综合久久天天综线观看| 日韩精品久久久久久免费| 中文字幕亚洲综合久久| 久久只有这精品99| 国产精品久久一区二区三区| 91精品国产综合久久四虎久久无码一级| 久久丝袜精品中文字幕| 香蕉久久av一区二区三区| 国产视频久久| 亚洲AV日韩精品久久久久久久 | 国产成人无码精品久久久久免费| 无码乱码观看精品久久| 91精品国产91久久久久久青草| 国产精品久久久久久久久软件| 国内精品久久久久| 久久精品国产99久久久古代| 久久99国产一区二区三区| 国内精品久久久人妻中文字幕|