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

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉(zhuǎn),開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            ICE編寫HELLO WORD

            Posted on 2010-05-12 23:37 S.l.e!ep.¢% 閱讀(1121) 評論(0)  編輯 收藏 引用 所屬分類: ICE
            ICE編寫HELLO WORD

            有關(guān)ICE的基礎(chǔ)知識,請參照前面的ICE專題文章。由于這些文章均來自于網(wǎng)絡(luò),故未發(fā)之于首頁。下面僅僅給出相關(guān)link:

            ICE專題:利用ICE編寫程序的幾個注意點

            ICE專題:ICE架構(gòu)

            ICE專題:ICE起步

            ICE專題:ICE的5個服務

            ICE專題:使用C#編寫ICE分布式應用程序

            ICE專題:學習ICE 3.0

            ICE專題:在客戶端中如何定位服務器(即如何尋找代理)

            ICE專題:ICE在Linux下的安裝

            ICE專題:ICE簡介

            目標:在Windows平臺上編寫第一個基于ICE的Hello Word程序。


            1、安裝

            http://www.zeroc.com/download.html#bin下載安裝文件:

            Windows Installer for Visual Studio 2005

            Ice-3.2.0-VC80.msi 【必需】

            Everything needed to use Ice on Windows XP/Server 2003/Vista in C++, Java, C#, Visual Basic and Python. This installer includes executables, debug and release DLLs, header files, import libraries, PDBs, Java classes, sample programs, and third-party dependencies.

            Visual Studio 2005 is only required for C++, C#, and Visual Basic developers. Visual Studio 2005 Express compilers are also supported.

            Ice-3.2.0-ThirdParty-VC80.msi

            Use this installer if you want to build Ice for C++ or Ice for Java from sources. It includes header files, debug/release DLLs, and JAR files for Ice's third-party dependencies:

            • Berkeley DB 4.5.20
            • OpenSSL 0.9.8d
            • Libbzip2 1.0.3
            • Expat 2.0.0

            Ice for Java users who do not want to install the full Ice distribution may also find this installer useful, as it includes the Java classes for Berkeley DB.

            Ice for C#

            IceCS-3.2.0.tar.gz
            IceCS-3.2.0.zip

            The complete Ice for C# source code.

            Note that, to build Ice for C#, you must first compile Ice for C++ or, alternatively, download and install an appropriate binary distribution. This is necessary because the Slice-to-C# compiler is written in C++.

            以上的3個文件,Ice-x.x.-VC80.msi是ICE在Windows平臺下的運行時文件,包含了必需的庫文件,頭文件,和命令行工具。有關(guān)運行時的介紹,以后的專題文章將一一介紹(隨項目進度逐步介紹吧:P)。第3方庫,建議安裝,特別是用C++開發(fā)時。當然,如果不使用C++,就不必安裝了。ICE for C#的包,是個源碼庫,包含了ICE for C#的實現(xiàn),實際上是封裝了.NET Framework與ICE運行庫之間的交互,即.NET程序與C++程序的交互,會看到大量的平臺調(diào)用。如果起個更好的名字,也許稱之為“ICE for C# Provider/Wrapper"更好。

            注意安裝運行時后,需要添加環(huán)境變量ICE_HOME,并將%ICE_HOME%bin添加到Path中:

            2、建立C#控制臺項目

            啟動VS 2005,建立兩個控制臺項目,一個叫Server,一個叫Client。均添加對icecs.dll的引用。

            由于我的ICE運行時安裝于C:Ice-3.2.0,故在C:Ice-3.2.0bin下找到此文件,需要注意的是,一定要選擇:復制到本地。

            3、定義接口方法

            module Demo {
            interface Printer {
            void printString(string s);
            };
            };

            將這段代碼存為:Printer.ice。在此文件同目錄下,創(chuàng)建批處理命令文件cmd1.bat,內(nèi)容如下:

            																								mkdir generated
            slice2cs --output-dir generated Printer.ice
            																						

            運行cmd1.bat,則會在generated 文件夾下生成Printer.cs。這里暫時不分析Printer.cs的結(jié)構(gòu),直接使用它了。將Printer.cs拷貝到新建的兩個項目中,注意,你必須將項目中使用的namespace設(shè)置成相同的,例如,我將根namespace設(shè)置為Demo。

            4、添加應用邏輯

            在Client項目中添加Client.cs,內(nèi)容如下:

            																								using System;
            using System.Collections.Generic;
            using System.Text;
            namespace Demo
            {
            publicclass Client
            {
            publicstaticvoid Main(string[] args)
            {
            int status = 0;
            Ice.Communicator ic = null;
            try
            {
            ic = Ice.Util.initialize(ref args);
            Ice.ObjectPrx obj = ic.stringToProxy(
            "SimplePrinter:tcp -p 12345:udp -p 12345");
            PrinterPrx printer
            = PrinterPrxHelper.checkedCast(obj);
            if (printer == null)
            thrownew ApplicationException("Invalid proxy");
            printer.printString("Hello World!");
            }
            catch (Exception e)
            {
            Console.Error.WriteLine(e);
            status = 1;
            }
            if (ic != null)
            {
            // Clean up//try
            {
            ic.destroy();
            }
            catch (Exception e)
            {
            Console.Error.WriteLine(e);
            status = 1;
            }
            }
            Environment.Exit(status);
            }
            }
            }
            

            在server項目中,添加Server.cs文件,內(nèi)容如下:

            																								namespace Demo
            {
            using System;
            publicclass PrinterI : Demo.PrinterDisp_
            {
            publicoverridevoid printString(string s, Ice.Current current)
            {
            Console.WriteLine(s);
            }
            }
            publicclass Server
            {
            publicstaticvoid Main(string[] args)
            {
            int status = 0;
            Ice.Communicator ic = null;
            try
            {
            ic = Ice.Util.initialize(ref args);
            Ice.ObjectAdapter adapter
            = ic.createObjectAdapterWithEndpoints(
            "SimplePrinter", "tcp -p 12345:udp -p 12345");
            Ice.Object obj = new PrinterI();
            adapter.add(
            obj,
            Ice.Util.stringToIdentity("SimplePrinter"));
            adapter.activate();
            ic.waitForShutdown();
            }
            catch (Exception e)
            {
            Console.Error.WriteLine(e);
            status = 1;
            }
            if (ic != null)
            {
            // Clean up//try
            {
            ic.destroy();
            }
            catch (Exception e)
            {
            Console.Error.WriteLine(e);
            status = 1;
            }
            }
            Environment.Exit(status);
            }
            }
            }
            


            5、測試應用

            切換到Server項目的生成目錄,發(fā)現(xiàn)生成了server.exe程序,運行:Server.exe。
            如果你的OS安裝了網(wǎng)絡(luò)防火墻,注意開通相應的12345端口。最好關(guān)閉所有防火墻軟件后,測試應用程序。
            server.exe運行后,就一直處于監(jiān)聽狀態(tài)。運行netstat -an,可以看到服務器端程序監(jiān)聽著12345端口。

            在命令行下運行Client.exe,會發(fā)現(xiàn)Server.exe的控制臺顯示:Hello Word!

            注意事項:

            1、通信協(xié)議串請使用TCP或UDP,如以上所提供的那樣,ICE手冊中所給的協(xié)議是:"default -p 10000",這在我的平臺下并不可用,這需要給ICE配置默認設(shè)置。ICE設(shè)置使用 【程序名.config】 文件來配置,下面給出一個例子:

            #
            # The client reads this property to create the reference to the
            # "hello" object in the server.
            #
            Hello.Proxy=hello:tcp -p 10000:udp -p 10000:ssl -p 10001

            #
            # Warn about connection exceptions.
            #
            #Ice.Warn.Connections=1

            #
            # We want a faster ACM for this demo.
            #
            Ice.ACM.Client=10

            #
            # Network Tracing
            #
            # 0 = no network tracing
            # 1 = trace connection establishment and closure
            # 2 = like 1, but more detailed
            # 3 = like 2, but also trace data transfer
            #
            #Ice.Trace.Network=1

            #
            # Protocol Tracing
            #
            # 0 = no protocol tracing
            # 1 = trace protocol messages
            #
            #Ice.Trace.Protocol=1

            #
            # Security Tracing
            #
            # 0 = no security tracing
            # 1 = trace messages
            #
            #IceSSL.Trace.Security=1

            #
            # SSL Configuration
            #
            Ice.Plugin.IceSSL=icesslcs, Version=3.2.0.0, Culture=neutral, PublicKeyToken=1f998c50fec78381:IceSSL.PluginFactory
            IceSSL.DefaultDir=../../../certs
            IceSSL.ImportCert.CurrentUser.Root=cacert.pem
            IceSSL.CertFile=c_rsa1024.pfx
            IceSSL.Password=password
            Ice.ThreadPerConnection=1

            2、關(guān)閉防護墻
            當不關(guān)閉防火墻時,出現(xiàn)一些莫名其妙的問題,均是程序的TCP/IP出入受到了限制導致的。

            后記:

            最近項目使用了ICE來實現(xiàn)分布式應用,ICE的確功能強大,希望使用過的朋友或?qū)CE關(guān)注的朋友能一起交流交流經(jīng)驗,彼此提高。【開源應用技術(shù)群 25935569】 。

            94久久国产乱子伦精品免费| 中文字幕人妻色偷偷久久| 久久国产精品无码HDAV| 18岁日韩内射颜射午夜久久成人| 国产精品99久久不卡| 欧美精品丝袜久久久中文字幕| 亚洲精品无码久久毛片| 久久97精品久久久久久久不卡| 久久久99精品成人片中文字幕| 亚洲午夜久久久久妓女影院| 91久久精品国产91性色也| 久久久久久曰本AV免费免费| 国产亚洲精午夜久久久久久 | 国产毛片久久久久久国产毛片| 久久久久久国产精品美女 | AV无码久久久久不卡网站下载 | 人妻无码精品久久亚瑟影视| 亚洲一区二区三区日本久久九| 亚洲乱码精品久久久久..| 综合久久给合久久狠狠狠97色| 精品综合久久久久久97超人 | 久久精品国产亚洲AV不卡| 蜜臀av性久久久久蜜臀aⅴ| 欧美久久久久久精选9999| 99久久免费国产精精品| 久久久久se色偷偷亚洲精品av| 九九久久精品国产| 国产99久久久国产精品~~牛| 亚洲国产另类久久久精品黑人| 久久中文字幕人妻丝袜| 久久久久国产| 精品久久久久久无码免费| 91久久精品电影| 99久久99久久精品国产片果冻| 狠狠久久亚洲欧美专区| 久久er热视频在这里精品| 91精品国产91久久久久福利| 国产成人无码久久久精品一| 亚洲国产成人久久精品动漫| 国产精品丝袜久久久久久不卡| 9999国产精品欧美久久久久久|