• <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 閱讀(4639) 評論(3)  編輯 收藏 引用 所屬分類: COMC++

            評論

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

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

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

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

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

            后面還有嗎?謝謝
            2009-04-05 23:54 | 螢火蟲
            亚洲欧美久久久久9999 | 亚洲中文久久精品无码ww16| 国产精品久久久久久久久鸭| 精品久久亚洲中文无码| 午夜精品久久久久久毛片| 精品熟女少妇AV免费久久| 亚洲中文字幕无码久久综合网| 久久国语露脸国产精品电影| 久久久久亚洲AV综合波多野结衣| 91精品国产高清久久久久久国产嫩草| 久久w5ww成w人免费| 久久久久人妻一区二区三区vr| 国产亚洲精品久久久久秋霞| 色综合久久无码中文字幕| 久久精品无码午夜福利理论片| 国产精品久久影院| 嫩草影院久久国产精品| 国产女人aaa级久久久级| 久久久噜噜噜久久| 久久久久久精品成人免费图片| 午夜精品久久久久久久| 欧美综合天天夜夜久久| 性做久久久久久久久| 亚洲AV成人无码久久精品老人| 2021精品国产综合久久| 亚洲午夜精品久久久久久浪潮 | 伊人久久大香线蕉av一区| 亚洲国产精品久久电影欧美| 成人久久久观看免费毛片| 久久精品国产WWW456C0M| 欧美亚洲国产精品久久| 久久国产精品久久精品国产| 欧美久久综合九色综合| 久久精品国产亚洲av麻豆小说| 香蕉久久夜色精品国产小说| 思思久久99热只有频精品66| 久久精品国产亚洲麻豆| 伊人久久大香线蕉综合Av| 99久久无码一区人妻| 久久国产精品无码一区二区三区| 免费精品99久久国产综合精品|