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

            twzheng's cppblog

            『站在風(fēng)口浪尖緊握住鼠標(biāo)旋轉(zhuǎn)!』 http://www.cnblogs.com/twzheng

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              136 隨筆 :: 78 文章 :: 353 評論 :: 0 Trackbacks

            GetQueuedCompletionStatus函數(shù)有個OVERLAPPED結(jié)構(gòu),很多資料上都采用不同的結(jié)構(gòu)體來擴(kuò)展該結(jié)構(gòu),比如有的資料定義:
            typedef struct _OVERLAPPEDPLUS
            {
            OVERLAPPED ol;
            SOCKET s, sclient;
            int OpCode;
            WSABUF wbuf;
            DWORD dwBytes, dwFlags;
            }OVERLAPPEDPLUS;

            然后,當(dāng)GetQueuedCompletionStatus(hIocp, &dwBytesXfered,(PULONG_PTR)&PerHandleKey, &Overlap, INFINITE);函數(shù)返回時候,人們常用OverlapPlus = CONTAINING_RECORD(Overlap, OVERLAPPEDPLUS, ol)得到一些信息。比如此時端口上完成的是什么操作,數(shù)據(jù)是什么等,還有,系統(tǒng)如何做到自動填充上述的結(jié)構(gòu)的,也就是說,系統(tǒng)怎么知道在Overlap->OpCode存放的應(yīng)該是操作類型,如讀,寫操作,而在Overlap->wbuf存放的應(yīng)該是讀寫數(shù)據(jù)。


            Overlap->OpCode,操作類型是在投遞WSASend,WSARecv的時候,由你自己指定填充這個字段。

            因為是非堵塞的,等于投遞到與套接字相關(guān)聯(lián)的完成端口上,系統(tǒng)會把把WSASend對應(yīng)的緩沖區(qū)提交到底層緩沖,也可以把WSARecv投遞的緩沖區(qū),用接收到的數(shù)據(jù)填充,每一個WSASend,WSARecv,都應(yīng)有新申請一個overlaspped plus結(jié)構(gòu)提交,以存放本次投遞的IO操作的相關(guān)數(shù)據(jù),——單IO操作數(shù)據(jù)所以工作器線程中,從完成端口隊列中g(shù)et得到一個完成包的時候,可以根據(jù)單句柄數(shù)據(jù)知道在這個完成端口上是哪一個套接字投遞的IO操作完成了,從get到的overlapped中得到相關(guān)的已經(jīng)完成IO數(shù)據(jù)和信息,并作相應(yīng)的處理。比如投遞了1M,完成包卻告知只完成512K,那么你就知道要把余下的512K繼續(xù)投遞WSASend,當(dāng)然上一個WSASend的Overlapped這個時候可以重用到下一個WSASend中,這個是允許的,可以用一個字段存放全部1M,把余下未Send成功512k放到wbuf中,繼續(xù)投遞或者投遞WSARecv1M數(shù)據(jù),卻收到一個512K的完成通知,那么你要繼續(xù)投遞WSARecv,當(dāng)然前一個WSARecv的overlapped也可以重用,不過需要一些處理,把已經(jīng)接收到的512K保存到某個字段中,再投遞一個512K的請求去接收完成端口內(nèi)部,對投遞的Overlapped的填充,好像只有WSARecv的時候填充WSABUF,其他都是投遞IO前,代碼中顯式填充,并投遞的。至于完成了多少個字節(jié),是在lpNumberOfBytes中得到。

            對GetQueuedCompletionStatus函數(shù)解釋:
            實現(xiàn)從指定的IOCP獲取CP。當(dāng)CP隊列為空時,對此函數(shù)的調(diào)用將被阻塞,而不是一直等待I/O的完成。當(dāng)CP隊列不為空時,被阻塞的線程將以后進(jìn)先出(LIFO)順序被釋放。對于IOCP機(jī)制,它允許多線程并發(fā)調(diào)用GetQueuedCompletionStatus函數(shù),最大并發(fā)數(shù)是在調(diào)用CreateIoCompletionPort函數(shù)時指定的,超出最大并發(fā)數(shù)的調(diào)用線程,將被阻塞。函數(shù)解釋如下:  
              聲明:  
              BOOL   GetQueuedCompletionStatus(  
                      HANDLE   CompletionPort,    
                      LPDWORD   lpNumberOfBytes,    
                      PULONG_PTR   lpCompletionKey,    
                      LPOVERLAPPED   *lpOverlapped,    
                      DWORD   dwMilliseconds);  
              調(diào)用參數(shù):  
              CompletionPort:指定的IOCP,該值由CreateIoCompletionPort函數(shù)創(chuàng)建。  
              lpnumberofbytes:一次完成后的I/O操作所傳送數(shù)據(jù)的字節(jié)數(shù)。  
              lpcompletionkey:當(dāng)文件I/O操作完成后,用于存放與之關(guān)聯(lián)的CK。  
              lpoverlapped:為調(diào)用IOCP機(jī)制所引用的OVERLAPPED結(jié)構(gòu)。  
              dwmilliseconds:用于指定調(diào)用者等待CP的時間。  
              返回值:  
              調(diào)用成功,則返回非零數(shù)值,相關(guān)數(shù)據(jù)存于lpNumberOfBytes、lpCompletionKey、lpCompletionKey變量中。失敗則返回零值。

            posted on 2007-04-16 00:55 譚文政 閱讀(12802) 評論(0)  編輯 收藏 引用 所屬分類: 網(wǎng)絡(luò)編程

            評論

            # re: GetQueuedCompletionStatus函數(shù) 2008-11-27 22:47 王博煒
            不錯  回復(fù)  更多評論
              

            久久久久久综合网天天| 国产毛片久久久久久国产毛片| 久久香蕉超碰97国产精品 | 久久人与动人物a级毛片| 久久精品国产亚洲av麻豆色欲| 伊人久久综在合线亚洲2019| 亚洲国产婷婷香蕉久久久久久| www.久久热| 精品多毛少妇人妻AV免费久久| 国产成人久久久精品二区三区| 色偷偷久久一区二区三区| 欧美精品一区二区久久| 91秦先生久久久久久久| 久久久久久国产精品免费无码| 亚洲欧美成人久久综合中文网| 久久香蕉一级毛片| 久久亚洲日韩精品一区二区三区| 日韩va亚洲va欧美va久久| 亚洲一本综合久久| 久久777国产线看观看精品| 久久夜色精品国产欧美乱| 久久午夜无码鲁丝片秋霞 | 色欲久久久天天天综合网精品| 久久天天躁狠狠躁夜夜av浪潮| 精品久久人妻av中文字幕| 久久99久久99精品免视看动漫| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 国产成人综合久久精品尤物| 99久久er这里只有精品18| 婷婷久久久亚洲欧洲日产国码AV| 亚洲精品无码专区久久同性男| 久久精品亚洲精品国产欧美| 国产激情久久久久影院小草 | 久久w5ww成w人免费| 欧洲精品久久久av无码电影| 久久久一本精品99久久精品66| 精品熟女少妇AV免费久久 | 精品无码久久久久久久动漫| 99久久免费国产特黄| 日本精品久久久久中文字幕 | 99久久精品费精品国产一区二区 |