• <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>
            隨筆 - 60, 文章 - 0, 評論 - 197, 引用 - 0
            數(shù)據(jù)加載中……

            Win32 RPC 編程(三)

            我們在上一節(jié)的基礎上,討論如何實現(xiàn)異步的 RPC 調(diào)用。前兩節(jié)演示的函數(shù)調(diào)用都是同步的,即調(diào)用函數(shù) Hello() 時,
            客戶端將阻塞住直到服務端的 Hello() 函數(shù)返回。如果服務端函數(shù)需要進行一些費時的操作,例如復雜的計算、查詢,
            客戶端只能一直阻塞在那里。這種情況下,我們可以使用異步的 RPC 提高客戶端的性能。

            異步的RPC是通過配置文件(.acf)來啟用的:
            --------------------------------------------
            Hello.acf:

            [  
                   implicit_handle(handle_t HelloWorld_Binding)  
            ]  

            interface  HelloWorld
            {
                   [async] Hello();  // 增加了 [async] 表明這是異步調(diào)用
            }

             
            原來的接口 HelloWorld 有兩個方法,Hello() 和 Shutdown(),Shutdown() 我們?nèi)匀蛔屗峭秸{(diào)用,所以在.acf文
            件中不用列出。IDL 接口文件還是可以不用修改。


            服務端的代碼 server.c 中的 Hello() 要改成下面的樣子:
            ------------------------------------------------------
            void Hello(PRPC_ASYNC_STATE rpcAsyncHandle, const unsigned char * psz)
            {
                 // 模擬一個長時間的操作
                 printf("Sleep 5 seconds...\n");
                 Sleep(5000);
             

                 printf("%s\n", psz);
                 // 表明調(diào)用已經(jīng)完成

                 RpcAsyncCompleteCall(rpcAsyncHandle, NULL);
            }

            服務端的其它代碼不用修改。
             

            客戶端client.c中的調(diào)用方式也要換:
            ---------------------------------
            int main(int argc, char * argv[])
            {
                 // 前面都相同
                 ...
               
                 // 下面是調(diào)用服務端的函數(shù)
                 RpcTryExcept
                 {

                     if ( _stricmp(argv[1], "SHUTDOWN") == 0 )
                     {
                          Shutdown();
                     }
                     else
                     {
                          // 初始化異步調(diào)用
                          RPC_ASYNC_STATE async;
                          RpcAsyncInitializeHandle( &async, sizeof(async) );
                          async.UserInfo = NULL;
                          async.NotificationType = RpcNotificationTypeNone;

                          // 本函數(shù)能立即返回
                          Hello( &async, (unsigned char*)argv[1]);

                          // 查詢調(diào)用的狀態(tài)
                          while ( RpcAsyncGetCallStatus(&async) == RPC_S_ASYNC_CALL_PENDING )
                          {
                               printf("Call Hello() pending, wait 1s...\n");
                               Sleep(1000);
                          }

                          // 通知調(diào)用已經(jīng)完成
                          RpcAsyncCompleteCall( &async, NULL );
                     }
                 }
                 RpcExcept(1)
                 {
                     printf( "RPC Exception %d\n", RpcExceptionCode() );
                 }
                 RpcEndExcept

               
                 // 后面都相同
                 ...
            }

            這樣客戶端就實現(xiàn)了異步調(diào)用!

            示例下載
             

            posted on 2008-04-29 11:22 Normandy 閱讀(2784) 評論(1)  編輯 收藏 引用 所屬分類: Networking

            評論

            # re: Win32 RPC 編程(三)  回復  更多評論   

            我最近正在Windows下開發(fā)RPC服務器與客戶端程序,現(xiàn)在只是前期熟悉試驗階段,網(wǎng)上的hello world程序已經(jīng)可以正常運行了,但是我現(xiàn)在想在服務器端返回二進制流,IDL中定義的接口如下:

            char* helloworld([in,string]const char* psz)

            在服務器端實現(xiàn)代碼如下:
            unsigned char* helloworld(const unsigned char* psz)
            {
            unsigned char* pTest = new unsigned char[4] ;
            int nTest = 100 ;
            memcpy(pTtest,&nTest,4) ;

            return pTtest ;
            }

            客戶端調(diào)用方式
            unsigned char* pTest = helloworld((unsigned char*)"Hello Server!");
            int nTest ;
            memcpy(&nTest ,pTest,4) ;

            nTest得到的很大的一個數(shù),pTest的內(nèi)容也不對,請問大家應該怎樣定義接口文件,怎樣才能得到正確的返回值呢?謝謝了
            2013-09-04 19:43 | forest21000
            欧美日韩精品久久久久| 久久精品国产秦先生| 97视频久久久| 精品国产91久久久久久久| 一本一道久久精品综合 | 无码伊人66久久大杳蕉网站谷歌| 久久精品亚洲中文字幕无码麻豆| 亚洲综合精品香蕉久久网97 | 久久亚洲日韩精品一区二区三区 | 久久精品无码专区免费 | 久久99精品久久久久久久不卡| 久久99精品国产麻豆婷婷| 久久久久久久女国产乱让韩| 久久er热视频在这里精品| 久久精品国产清自在天天线| 精品无码久久久久久久动漫| 久久精品夜夜夜夜夜久久| yy6080久久| 狠狠色丁香久久婷婷综合蜜芽五月| 日产精品99久久久久久| 中文字幕亚洲综合久久菠萝蜜| 99久久婷婷国产一区二区| 国产精品禁18久久久夂久| 久久久精品2019免费观看| 亚洲伊人久久综合影院| 久久中文精品无码中文字幕| 久久国产精品免费| 国产成人久久精品二区三区| 精品国产91久久久久久久| 777米奇久久最新地址| 国产V综合V亚洲欧美久久| 久久婷婷五月综合97色| 久久天堂AV综合合色蜜桃网 | 国产午夜久久影院| 99精品国产在热久久| 国产精品美女久久久m| 97久久超碰国产精品2021| 青青青青久久精品国产| 91精品国产综合久久四虎久久无码一级 | 国产精品日韩欧美久久综合| 久久精品视频网|