• <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
            亚洲午夜久久久久久久久久| 久久综合色区| 国产成人精品久久二区二区| 久久久国产乱子伦精品作者| 99久久精品国产综合一区| 久久一本综合| 国产精品女同久久久久电影院| 久久综合综合久久97色| 囯产精品久久久久久久久蜜桃| 久久99国产亚洲高清观看首页 | 手机看片久久高清国产日韩| 精品久久久无码人妻中文字幕| 久久91精品国产91久久麻豆| 久久综合亚洲鲁鲁五月天| 996久久国产精品线观看| 久久婷婷国产剧情内射白浆| 国产一区二区三区久久精品| 久久久久高潮综合影院| 国产精品成人精品久久久 | 7国产欧美日韩综合天堂中文久久久久| 久久久久亚洲精品男人的天堂| 国产精品一区二区久久国产| 国产亚洲美女精品久久久2020| 久久人妻少妇嫩草AV无码蜜桃| 99久久精品毛片免费播放| 伊人久久大香线蕉av一区| 亚洲&#228;v永久无码精品天堂久久 | 久久国产亚洲精品无码| 久久亚洲国产成人影院| 日韩精品无码久久一区二区三| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 久久综合久久美利坚合众国 | 国产精品免费看久久久| 国内精品人妻无码久久久影院| 人妻无码中文久久久久专区| 伊人 久久 精品| 久久青青草原精品影院| 99国产欧美精品久久久蜜芽| 久久99精品国产自在现线小黄鸭| 久久久精品人妻一区二区三区四 | 亚洲AV无码一区东京热久久|