青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

穩(wěn)定盈利的期貨交易方法-量化趨勢交易

alantop -專業(yè)量化投資者

愛好:量化投資,逆向工程,滲透
隨筆 - 595, 文章 - 0, 評論 - 921, 引用 - 0
數(shù)據(jù)加載中……

Windows完成端口編程

目錄
一 基本概念
二 OVERLAPPED數(shù)據(jù)結(jié)構(gòu)
三 完成端口的內(nèi)部機制
創(chuàng)建完成端口
完成端口線程的工作原理
線程間數(shù)據(jù)傳遞
線程的安全退出

一 基本概念
???????設備---windows操作系統(tǒng)上允許通信的任何東西,比如文件、目錄、串行口、并行口、郵件槽、命名管道、無名管道、套接字、控制臺、邏輯磁盤、物理磁盤等。絕大多數(shù)與設備打交道的函數(shù)都是CreateFile/ReadFile/WriteFile等。所以我們不能看到**File函數(shù)就只想到文件設備。

???????與設備通信有兩種方式,同步方式和異步方式。同步方式下,當調(diào)用ReadFile函數(shù)時,函數(shù)會等待系統(tǒng)執(zhí)行完所要求的工作,然后才返回;異步方式下,ReadFile這類函數(shù)會直接返回,系統(tǒng)自己去完成對設備的操作,然后以某種方式通知完成操作。

???????重疊I/O----顧名思義,當你調(diào)用了某個函數(shù)(比如ReadFile)就立刻返回做自己的其他動作的時候,同時系統(tǒng)也在對I/0設備進行你要求的操作,在這段時間內(nèi)你的程序和系統(tǒng)的內(nèi)部動作是重疊的,因此有更好的性能。所以,重疊I/O是用于異步方式下使用I/O設備的。

重疊I/O需要使用的一個非常重要的數(shù)據(jù)結(jié)構(gòu)OVERLAPPED。

???????完成端口---是一種WINDOWS內(nèi)核對象。完成端口用于異步方式的重疊I/0情況下,當然重疊I/O不一定非使用完成端口不可,還有設備內(nèi)核對象、事件對象、告警I/0等。但是完成端口內(nèi)部提供了線程池的管理,可以避免反復創(chuàng)建線程的開銷,同時可以根據(jù)CPU的個數(shù)靈活的決定線程個數(shù),而且可以讓減少線程調(diào)度的次數(shù)從而提高性能。





二 OVERLAPPED數(shù)據(jù)結(jié)構(gòu)
typedef struct _OVERLAPPED {



????ULONG_PTR Internal;//被系統(tǒng)內(nèi)部賦值,用來表示系統(tǒng)狀態(tài)



????ULONG_PTR InternalHigh;// 被系統(tǒng)內(nèi)部賦值,傳輸?shù)淖止?jié)數(shù)



????union {



????????struct {



????????????DWORD Offset;//和OffsetHigh合成一個64位的整數(shù),用來表示從文件頭部的多少字節(jié)開始



????????????DWORD OffsetHigh;//操作,如果不是對文件I/O來操作,則必須設定為0



????????};



????????PVOID Pointer;



????};



????HANDLE??hEvent;//如果不使用,就務必設為0,否則請賦一個有效的Event句柄



} OVERLAPPED, *LPOVERLAPPED;







下面是異步方式使用ReadFile的一個例子



OVERLAPPED Overlapped;



Overlapped.Offset=345;



Overlapped.OffsetHigh=0;



Overlapped.hEvent=0;



//假定其他參數(shù)都已經(jīng)被初始化



ReadFile(hFile,buffer,sizeof(buffer),&dwNumBytesRead,&Overlapped);



這樣就完成了異步方式讀文件的操作,然后ReadFile函數(shù)返回,由操作系統(tǒng)做自己的事情吧



?????



下面介紹幾個與OVERLAPPED結(jié)構(gòu)相關的函數(shù)



等待重疊I/0操作完成的函數(shù)



BOOL GetOverlappedResult (

HANDLE hFile,

LPOVERLAPPED lpOverlapped,//接受返回的重疊I/0結(jié)構(gòu)

LPDWORD lpcbTransfer,//成功傳輸了多少字節(jié)數(shù)

BOOL fWait //TRUE只有當操作完成才返回,F(xiàn)ALSE直接返回,如果操作沒有完成,通過調(diào)//用GetLastError ( )函數(shù)會返回ERROR_IO_INCOMPLETE



);





宏HasOverlappedIoCompleted可以幫助我們測試重疊I/0操作是否完成,該宏對OVERLAPPED結(jié)構(gòu)的Internal成員進行了測試,查看是否等于STATUS_PENDING值。











三 完成端口的內(nèi)部機制
創(chuàng)建完成端口

???????完成端口是一個內(nèi)核對象,使用時他總是要和至少一個有效的設備句柄進行關聯(lián),完成端口是一個復雜的內(nèi)核對象,創(chuàng)建它的函數(shù)是:

HANDLE CreateIoCompletionPort(



????IN HANDLE FileHandle,



????IN HANDLE ExistingCompletionPort,



????IN ULONG_PTR CompletionKey,



????IN DWORD NumberOfConcurrentThreads



????);







通常創(chuàng)建工作分兩步:

第一步,創(chuàng)建一個新的完成端口內(nèi)核對象,可以使用下面的函數(shù):

???????HANDLE CreateNewCompletionPort(DWORD dwNumberOfThreads)



{



??????????return CreateIoCompletionPort(INVALID_HANDLE_VALUE,NULL,NULL,dwNumberOfThreads);



};

???????

第二步,將剛創(chuàng)建的完成端口和一個有效的設備句柄關聯(lián)起來,可以使用下面的函數(shù):

???????bool AssicoateDeviceWithCompletionPort(HANDLE hCompPort,HANDLE hDevice,DWORD dwCompKey)



{



??????????HANDLE h=CreateIoCompletionPort(hDevice,hCompPort,dwCompKey,0);



??????????return h==hCompPort;



};



說明



1)??CreateIoCompletionPort函數(shù)也可以一次性的既創(chuàng)建完成端口對象,又關聯(lián)到一個有效的設備句柄



2)??CompletionKey是一個可以自己定義的參數(shù),我們可以把一個結(jié)構(gòu)的地址賦給它,然后在合適的時候取出來使用,最好要保證結(jié)構(gòu)里面的內(nèi)存不是分配在棧上,除非你有十分的把握內(nèi)存會保留到你要使用的那一刻。

3)??NumberOfConcurrentThreads通常用來指定要允許同時運行的的線程的最大個數(shù)。通常我們指定為0,這樣系統(tǒng)會根據(jù)CPU的個數(shù)來自動確定。





創(chuàng)建和關聯(lián)的動作完成后,系統(tǒng)會將完成端口關聯(lián)的設備句柄、完成鍵作為一條紀錄加入到這個完成端口的設備列表中。如果你有多個完成端口,就會有多個對應的設備列表。如果設備句柄被關閉,則表中自動刪除該紀錄。











完成端口線程的工作原理

???????完成端口可以幫助我們管理線程池,但是線程池中的線程需要我們使用_beginthreadex來創(chuàng)建,憑什么通知完成端口管理我們的新線程呢?答案在函數(shù)GetQueuedCompletionStatus。該函數(shù)原型:



BOOL GetQueuedCompletionStatus(



????IN??HANDLE CompletionPort,



????OUT LPDWORD lpNumberOfBytesTransferred,



????OUT PULONG_PTR lpCompletionKey,



????OUT LPOVERLAPPED *lpOverlapped,



????IN??DWORD dwMilliseconds



);



這個函數(shù)試圖從指定的完成端口的I/0完成隊列中抽取紀錄。只有當重疊I/O動作完成的時候,完成隊列中才有紀錄。凡是調(diào)用這個函數(shù)的線程將被放入到完成端口的等待線程隊列中,因此完成端口就可以在自己的線程池中幫助我們維護這個線程。



完成端口的I/0完成隊列中存放了當重疊I/0完成的結(jié)果---- 一條紀錄,該紀錄擁有四個字段,前三項就對應GetQueuedCompletionStatus函數(shù)的2、3、4參數(shù),最后一個字段是錯誤信息dwError。我們也可以通過調(diào)用PostQueudCompletionStatus模擬完成了一個重疊I/0操作。



當I/0完成隊列中出現(xiàn)了紀錄,完成端口將會檢查等待線程隊列,該隊列中的線程都是通過調(diào)用GetQueuedCompletionStatus函數(shù)使自己加入隊列的。等待線程隊列很簡單,只是保存了這些線程的ID。完成端口會按照后進先出的原則將一個線程隊列的ID放入到釋放線程列表中,同時該線程將從等待GetQueuedCompletionStatus函數(shù)返回的睡眠狀態(tài)中變?yōu)榭烧{(diào)度狀態(tài)等待CPU的調(diào)度。



基本上情況就是如此,所以我們的線程要想成為完成端口管理的線程,就必須要調(diào)用



GetQueuedCompletionStatus函數(shù)。出于性能的優(yōu)化,實際上完成端口還維護了一個暫停線程列表,具體細節(jié)可以參考《Windows高級編程指南》,我們現(xiàn)在知道的知識,已經(jīng)足夠了。



????



線程間數(shù)據(jù)傳遞

???????線程間傳遞數(shù)據(jù)最常用的辦法是在_beginthreadex函數(shù)中將參數(shù)傳遞給線程函數(shù),或者使用全局變量。但是完成端口還有自己的傳遞數(shù)據(jù)的方法,答案就在于CompletionKey和OVERLAPPED參數(shù)。

CompletionKey被保存在完成端口的設備表中,是和設備句柄一一對應的,我們可以將與設備句柄相關的數(shù)據(jù)保存到CompletionKey中,或者將CompletionKey表示為結(jié)構(gòu)指針,這樣就可以傳遞更加豐富的內(nèi)容。這些內(nèi)容只能在一開始關聯(lián)完成端口和設備句柄的時候做,因此不能在以后動態(tài)改變。

OVERLAPPED參數(shù)是在每次調(diào)用ReadFile這樣的支持重疊I/0的函數(shù)時傳遞給完成端口的。我們可以看到,如果我們不是對文件設備做操作,該結(jié)構(gòu)的成員變量就對我們幾乎毫無作用。我們需要附加信息,可以創(chuàng)建自己的結(jié)構(gòu),然后將OVERLAPPED結(jié)構(gòu)變量作為我們結(jié)構(gòu)變量的第一個成員,然后傳遞第一個成員變量的地址給ReadFile函數(shù)。因為類型匹配,當然可以通過編譯。當GetQueuedCompletionStatus函數(shù)返回時,我們可以獲取到第一個成員變量的地址,然后一個簡單的強制轉(zhuǎn)換,我們就可以把它當作完整的自定義結(jié)構(gòu)的指針使用,這樣就可以傳遞很多附加的數(shù)據(jù)了。太好了!只有一點要注意,如果跨線程傳遞,請注意將數(shù)據(jù)分配到堆上,并且接收端應該將數(shù)據(jù)用完后釋放。我們通常需要將ReadFile這樣的異步函數(shù)的所需要的緩沖區(qū)放到我們自定義的結(jié)構(gòu)中,這樣當GetQueuedCompletionStatus被返回時,我們的自定義結(jié)構(gòu)的緩沖區(qū)變量中就存放了I/0操作的數(shù)據(jù)。



CompletionKey和OVERLAPPED參數(shù),都可以通過GetQueuedCompletionStatus函數(shù)獲得。

線程的安全退出

???????很多線程為了不止一次的執(zhí)行異步數(shù)據(jù)處理,需要使用如下語句

while (true)

{

???????.。。。。。。

???????GetQueuedCompletionStatus(...);



??????????????。。。。。。

}

那么如何退出呢,答案就在于上面曾提到的PostQueudCompletionStatus函數(shù),我們可以用它發(fā)送一個自定義的包含了OVERLAPPED成員變量的結(jié)構(gòu)地址,里面包含一個狀態(tài)變量,當狀態(tài)變量為退出標志時,線程就執(zhí)行清除動作然后退出。

posted on 2006-06-02 10:32 AlanTop 閱讀(711) 評論(0)  編輯 收藏 引用 所屬分類: C++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产日韩一级| 久久久久久久尹人综合网亚洲| 精品二区视频| 国产无遮挡一区二区三区毛片日本| 国产精品你懂的在线| 国产伦精品一区二区三区在线观看| 国产精品欧美经典| 国产一区二区三区四区在线观看| 精品动漫3d一区二区三区免费版 | 亚洲欧美制服另类日韩| 亚洲欧美一区二区在线观看| 欧美在线观看网站| 欧美xx视频| 欧美午夜精品久久久久久久| 国产精品一区二区欧美| 精品999网站| 在线视频日韩| 久久久久久亚洲精品不卡4k岛国| 欧美暴力喷水在线| 中文在线一区| 久久中文精品| 国产精品免费观看视频| 91久久国产综合久久| 午夜精品久久久久久久99热浪潮| 美女任你摸久久| 亚洲视频中文| 欧美二区在线播放| 国产亚洲午夜| 亚洲视频在线免费观看| 蜜桃久久av| 亚洲一区在线直播| 欧美精品v日韩精品v国产精品| 国产精品黄色在线观看| 亚洲精品韩国| 久久久久久久久久久久久久一区| 亚洲三级国产| 久久久亚洲高清| 国产精品一卡| 久久久久国产精品午夜一区| 欧美日韩精品在线观看| 一区二区在线观看av| 欧美一区二区| 中日韩午夜理伦电影免费| 欧美~级网站不卡| 黄色影院成人| 久久噜噜亚洲综合| 欧美一区二区三区在| 国产精品久久999| 一区二区三区精品久久久| 老司机一区二区| 性做久久久久久久免费看| 国产精品久久久久久久久久直播| 亚洲精品国产品国语在线app| 狼人天天伊人久久| 久久精品人人爽| 伊人激情综合| 欧美a级一区| 免费在线欧美黄色| 亚洲人成在线播放网站岛国| 欧美激情一区二区三区| 久久亚洲图片| 亚洲大片免费看| 欧美激情第六页| 欧美日本韩国| 亚洲综合999| 亚洲制服少妇| 国产亚洲一区二区三区在线观看| 午夜宅男久久久| 欧美一区二区三区在线视频| 国产女人18毛片水18精品| 久久精品99国产精品| 久久久久国产精品一区| 亚洲精品乱码久久久久| 亚洲精品一区二| 国产精品卡一卡二| 久久久久久久久岛国免费| 久久久综合激的五月天| 亚洲乱码视频| 亚洲小说春色综合另类电影| 国产精品久久久久免费a∨| 欧美一区免费视频| 久久免费视频一区| 亚洲精品影视| 亚洲私人影院在线观看| 国产精品一卡二| 欧美大成色www永久网站婷| 欧美国产精品劲爆| 欧美一区二区三区播放老司机| 久久精品国产清高在天天线| 尤物网精品视频| 日韩一级免费观看| 国产在线视频欧美一区二区三区| 麻豆精品传媒视频| 欧美午夜视频在线| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美国产一区视频在线观看 | 精品91在线| 夜久久久久久| 久久香蕉国产线看观看av| 日韩视频免费看| 欧美一区二区成人| av成人手机在线| 久久精品99无色码中文字幕| 一区二区不卡在线视频 午夜欧美不卡在 | 久久免费99精品久久久久久| 一卡二卡3卡四卡高清精品视频| 性高湖久久久久久久久| 一区二区三区成人精品| 久久久久99| 欧美在线观看一区二区| 欧美日本免费| 亚洲电影免费观看高清完整版| 国产日韩欧美综合精品| 一本色道久久综合亚洲精品不卡| 亚洲国产精品成人| 久久国产精品久久w女人spa| 亚洲综合电影| 欧美日韩一区二区国产| 欧美黄色网络| 亚洲国产91色在线| 久久精品国产91精品亚洲| 亚洲欧美久久久| 欧美日韩一区二区三区四区在线观看 | 欧美影院成年免费版| 欧美另类一区| 亚洲黄色尤物视频| 亚洲激情视频在线| 久久婷婷久久一区二区三区| 久久精品女人| 国产亚洲精品bv在线观看| 亚洲一区二区三区精品动漫| 亚洲午夜视频| 欧美小视频在线观看| 日韩亚洲欧美一区二区三区| 99这里只有久久精品视频| 欧美不卡高清| 欧美黄色片免费观看| 最新精品在线| 欧美日韩国产在线一区| 夜夜嗨一区二区| 午夜欧美精品| 国产日本欧美在线观看 | 欧美一区激情视频在线观看| 久久精品欧美| 在线观看国产精品网站| 蜜臀av性久久久久蜜臀aⅴ| 欧美激情精品久久久| 91久久久久久久久| 欧美老女人xx| 亚洲一区二区三区免费观看| 久久久久久久综合色一本| 加勒比av一区二区| 在线午夜精品自拍| 午夜精品久久久久久久久久久久| 国产欧美高清| 久久三级福利| 日韩亚洲一区二区| 欧美一区二区三区在线观看| 国产一本一道久久香蕉| 久久天堂av综合合色| 亚洲精品久久久久久下一站| 亚洲免费在线| 在线播放日韩| 欧美日韩在线观看一区二区| 亚洲尤物在线| 欧美va亚洲va香蕉在线| 亚洲视频在线观看网站| 狠狠色狠狠色综合日日91app| 欧美国产激情| 欧美一区二区三区四区在线观看 | 性做久久久久久| 亚洲第一精品福利| 午夜视频一区在线观看| 亚洲激情电影在线| 国产精品视频一区二区高潮| 免费欧美在线| 先锋影院在线亚洲| 亚洲人www| 久久综合精品国产一区二区三区| 一本色道久久综合狠狠躁篇怎么玩| 国产婷婷色一区二区三区四区| 欧美国产精品| 久久久久久穴| 小嫩嫩精品导航| 亚洲最新色图| 亚洲国内精品| 免费不卡在线视频| 欧美在线观看一区| 一区二区三区视频在线看| 伊人精品在线| 国产一区av在线| 国产精品白丝jk黑袜喷水| 久久综合色综合88| 久久av老司机精品网站导航| 亚洲网站啪啪| 国产精品99久久久久久宅男| 亚洲人成网站777色婷婷| 另类欧美日韩国产在线| 欧美一区二区日韩一区二区| 亚洲一区二区三区精品在线|