• <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>
            穩定盈利的期貨交易方法-量化趨勢交易

            alantop -專業量化投資者

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

            由淺入深,舉例講解RPC(一)

             

            關于RPC的文章很多,但是系統講解的很少。下面我將寫一個系列報道。用代碼和論述來把rpc來講講清楚。

            這篇就是開始第一篇了。

             

            由于工作比較忙。我們抽出一個星期的時間,有時間會寫一點。把這個系列寫完。所以,有可能每個系列都比較短些。

            從最基本的講起,讓大家徹底明白RPC.

             

            好了廢話不多說了。正是開始。

             

             

            首先,你要用RPC,必須先搞清楚什么是IDL.

             

            Rpc是什么?

            http://www.shnenglu.com/alantop/archive/2007/07/09/27717.html

            IDL是什么?

            http://www.shnenglu.com/alantop/archive/2007/07/09/27725.html

             

            下來,舉個例子。怎么樣把一個標準程序改成用IDL語言寫的程序。

             

            這是一個標準程序。

            // File Standalone.cpp

            #include <iostream>

             

            // Future server function.

            void Output(const char* szOutput)

            {

               std::cout << szOutput << std::endl;

            }

             

            int main()

            {

               // Future client call.

               Output("Hello Lonely World!");

            }

             

            下來看我們怎么把它改為一個標準IDL語言的程序

            IDL語言定義接口:

            // File Example1.idl

            [

               // A unique identifier that distinguishes this

               // interface from other interfaces.

               uuid(00000001-EAF3-4A7A-A0F2-BCE4C30DA77E),

             

               // This is version 1.0 of this interface.

               version(1.0),

             

               // This interface will use an implicit binding

               // handle named hExample1Binding.

               implicit_handle(handle_t hExample1Binding)

            ]

            interface Example1 // The interface is named Example1

            {

               // A function that takes a zero-terminated string.

               void Output(

                  [in, string] const char* szOutput);

            }

            上面這個文件是我們用idl語言定義的,我們定義了一個接口Example1, 它帶有uuidversion. 這個接口里定義了一個函數Output.

             

            UUID是什么?

            http://www.shnenglu.com/alantop/archive/2007/07/09/27726.html

             

             

            接口的implicit_handle屬性,我們后面再討論。

             

            接下來干什么呢?

            我們為了在程序中使用idl,必須通過通過編譯器(midl.exe)把它翻譯成客戶代理和服務器存根, 代理和存根將在后面被我們的編譯器(windows平臺下的cl.exe)所使用。

             

             

            改好的服務器端程序:

            // File Example1Server.cpp

            #include <iostream>

            #include "Example1.h"

             

            // Server function.

            void Output(const char* szOutput)

            {

               std::cout << szOutput << std::endl;

            }

             

            int main()

            {

               RPC_STATUS status;

             

               // Uses the protocol combined with the endpoint for receiving

               // remote procedure calls.

               status = RpcServerUseProtseqEp(

                  reinterpret_cast<unsigned char*>("ncacn_ip_tcp"), // Use TCP/IP

                                                                    // protocol.

                  RPC_C_PROTSEQ_MAX_REQS_DEFAULT, // Backlog queue length for TCP/IP.

                  reinterpret_cast<unsigned char*>("4747"), // TCP/IP port to use.

                  NULL); // No security.

             

               if (status)

                  exit(status);

             

               // Registers the Example1 interface.

               status = RpcServerRegisterIf(

                  Example1_v1_0_s_ifspec, // Interface to register.

                  NULL, // Use the MIDL generated entry-point vector.

                  NULL); // Use the MIDL generated entry-point vector.

             

               if (status)

                  exit(status);

             

               // Start to listen for remote procedure

               // calls for all registered interfaces.

               // This call will not return until

               // RpcMgmtStopServerListening is called.

               status = RpcServerListen(

                 1, // Recommended minimum number of threads.

                 RPC_C_LISTEN_MAX_CALLS_DEFAULT, // Recommended

                                        //maximum number of threads.

                 FALSE); // Start listening now.

             

               if (status)

                  exit(status);

            }

             

            // Memory allocation function for RPC.

            // The runtime uses these two functions for allocating/deallocating

            // enough memory to pass the string to the server.

            void* __RPC_USER midl_user_allocate(size_t size)

            {

                return malloc(size);

            }

             

            // Memory deallocation function for RPC.

            void __RPC_USER midl_user_free(void* p)

            {

                free(p);

            }

             

            這是初始化,和注冊接口的代碼。

             

            現在看看怎么寫客戶端

            // File Example1Client.cpp

            #include <iostream>

            #include "Example1.h"

             

            int main()

            {

               RPC_STATUS status;

               unsigned char* szStringBinding = NULL;

             

               // Creates a string binding handle.

               // This function is nothing more than a printf.

               // Connection is not done here.

               status = RpcStringBindingCompose(

                  NULL, // UUID to bind to.

                  reinterpret_cast<unsigned char*>("ncacn_ip_tcp"), // Use TCP/IP

                                                                    // protocol.

                  reinterpret_cast<unsigned char*>("localhost"), // TCP/IP network

                                                                 // address to use.

                  reinterpret_cast<unsigned char*>("4747"), // TCP/IP port to use.

                  NULL, // Protocol dependent network options to use.

                  &szStringBinding); // String binding output.

             

               if (status)

                  exit(status);

             

               // Validates the format of the string binding handle and converts

               // it to a binding handle.

               // Connection is not done here either.

               status = RpcBindingFromStringBinding(

                  szStringBinding, // The string binding to validate.

                  &hExample1Binding); // Put the result in the implicit binding

                                      // handle defined in the IDL file.

             

               if (status)

                  exit(status);

             

               RpcTryExcept

               {

                  // Calls the RPC function. The hExample1Binding binding handle

                  // is used implicitly.

                  // Connection is done here.

                  Output("Hello RPC World!");

               }

               RpcExcept(1)

               {

                  std::cerr << "Runtime reported exception " << RpcExceptionCode()

                            << std::endl;

               }

               RpcEndExcept

             

               // Free the memory allocated by a string.

               status = RpcStringFree(

                  &szStringBinding); // String to be freed.

             

               if (status)

                  exit(status);

             

               // Releases binding handle resources and disconnects from the server.

               status = RpcBindingFree(

                  &hExample1Binding); // Frees the implicit binding handle defined in

                                      // the IDL file.

             

               if (status)

                  exit(status);

            }

             

            // Memory allocation function for RPC.

            // The runtime uses these two functions for allocating/deallocating

            // enough memory to pass the string to the server.

            void* __RPC_USER midl_user_allocate(size_t size)

            {

                return malloc(size);

            }

             

            // Memory deallocation function for RPC.

            void __RPC_USER midl_user_free(void* p)

            {

                free(p);

            }

             

            posted on 2007-07-09 12:41 AlanTop 閱讀(4650) 評論(3)  編輯 收藏 引用 所屬分類: COMC++

            評論

            # re: 由淺入深,舉例講解RPC(一)[未登錄]  回復  更多評論   

            好文章!
            2007-07-09 17:13 | 111

            # re: 由淺入深,舉例講解RPC(一)  回復  更多評論   

            好,頂!!
            2007-07-13 17:07 | 黃大仙

            # re: 由淺入深,舉例講解RPC(一)  回復  更多評論   

            后面還有嗎?謝謝
            2009-04-05 23:54 | 螢火蟲
            伊人久久精品无码av一区| 99久久精品无码一区二区毛片 | 中文字幕无码精品亚洲资源网久久| 久久综合九色综合久99| 丁香久久婷婷国产午夜视频| 情人伊人久久综合亚洲| 色婷婷久久综合中文久久一本| 伊色综合久久之综合久久| 麻豆精品久久久久久久99蜜桃| 99精品久久精品一区二区| 久久久老熟女一区二区三区| 久久久久国产一级毛片高清版| 久久久久久久综合综合狠狠| 少妇久久久久久被弄到高潮| 久久久久久久久久久久中文字幕 | 国内精品久久久久久久coent| 久久综合伊人77777| 久久久久亚洲精品天堂| 天天综合久久一二三区| 精品久久久久久久无码 | 亚洲精品无码久久久久sm| 久久精品男人影院| 亚洲欧美一区二区三区久久| 精品久久香蕉国产线看观看亚洲| 午夜精品久久久久久久无码| 久久免费美女视频| 色诱久久久久综合网ywww| 伊人久久五月天| 精品欧美一区二区三区久久久 | 久久亚洲精品无码aⅴ大香| 国产精品毛片久久久久久久| 亚洲综合日韩久久成人AV| 国产精品成人99久久久久| 99久久精品费精品国产一区二区 | 国产成人精品综合久久久| 久久亚洲美女精品国产精品| 区久久AAA片69亚洲| 国产精品久久久久久久人人看 | 久久婷婷色综合一区二区| 久久成人影院精品777| 久久99精品久久久久久动态图 |