zeroC的Ice开发过程,进行了简单的学习,对构架的就不介绍的,分布式的,开发hello的过程如下:
1、按 slice 格式建立一个文本文件(hello.ice),本例的内容如下:
module dice{
interface Hello{
string say(string s);
};
};
//slice2java --output-dir demo hello.ice
2、运行 ice 的bin 目录下的 slice2java 程序,假设生成的代码放在 demo 目录下,在 dos 下输入:
slice2java --output-dir demo hello.ice
如不能运行,请设置好 path 到 ice 的bin 目录.
3.将 demo 目录下的 dice 目录copy到你的java项目源代码目录,建立一个 HelloI 的类(类命名方式:interface名+I)
内容如下:
package dice.mp;
import dice.*;
import Ice.*;
import java.util.*;
public class HelloI extends _HelloDisp {
public HelloI(){
System.out.println("cons:"+this);
}
public String say(String s, Ice.Current __current){
return "Hello "+s+",Time is "+new Date();
}
}
4.建立 server 和 client 文件。
server内容如下:
package dice.mp;
public class Server {
public static void main(String[] args) {
int status = 0;
Ice.Communicator ic = null;
try {
ic = Ice.Util.initialize(args);
Ice.ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints("HellorAdapter", "default -p 10000");
Ice.Object object = new HelloI();
adapter.add(object,ic.stringToIdentity("Hello"));
adapter.activate();
ic.waitForShutdown();
} catch (Ice.LocalException e) {
e.printStackTrace();
status = 1;
} catch (Exception e) {
System.err.println(e.getMessage());
status = 1;
}
if (ic != null) {
try {
ic.destroy();
} catch (Exception e) {
System.err.println(e.getMessage());
status = 1;
}
}
System.exit(status);
}
}
client 内容如下:
package dice.mp;
import dice.*;
import Ice.ObjectPrx;
import Ice.Util;
import Ice.Communicator;
public class Client {
public static void main(String[] args) throws Exception {
Communicator ic = null;
try {
ic = Util.initialize(args);
//Ice.ObjectPrx base = ic.stringToProxy("Hello:default -p 10000");
ObjectPrx base = ic.stringToProxy("Hello:tcp -h 127.0.0.1 -p 10000");
HelloPrx hello = HelloPrxHelper.checkedCast(base);
if (hello == null) throw new Error("Invalid proxy");
String msg=hello.say("机器人");
System.out.println(msg);
} catch (Ice.LocalException e) {
e.printStackTrace();
} catch (Exception e) {
System.err.println(e.getMessage());
}
if (ic != null) {
try {
ic.destroy();
System.out.println("通讯器关闭");
} catch (Exception e) {
System.err.println(e.getMessage());
}
}
}
}
5、运行、测试
注意要把ice 的 Ice.jar 设置到类路径中。
先运行 Server , 再运行 client .
到此,ok, 基本够用。
分享到:
相关推荐
标题 "Ice-3.5.1-el6-x86_64-rpm.tar.gz" 提供的是一个软件分发包的名称,其中包含了 Ice 的3.5.1版本,适用于64位的EL6(Enterprise Linux 6)操作系统。这个压缩包采用tar.gz格式,这是一种在Linux和Unix系统中...
ICE-2.0.3-for-64-bit-Windows, window10可用的图像拼接工具
标题中的“zeroc_ice-3.7.0-cp36-cp36m-win_amd64.whl”是指ZeroMQ ICE(Inter Process Communication)的一个Python绑定库的特定版本,适用于Python 3.6解释器,并且是为64位Windows系统编译的。ZeroMQ是一个开源的...
《Ice-3.5.1-4-ThirdParty:构建高效稳定的Windows开发环境》 Ice,全称为ZeroC Ice,是一款高性能、跨平台的中间件通信框架,它提供了丰富的语言支持,包括C++、Java、Python等,广泛应用于分布式系统中的服务间...
iceberg-spark-runtime-3.2_2.12-1.3.1.jar 实时数仓 数据湖
【ice-builder-eclipse】是一个专为Eclipse IDE设计的插件,主要用于支持ICE(Integrated Computing Environment)框架的开发。ICE是一种高性能、可扩展的中间件,由Object Computing, Inc. (OCI) 开发,用于构建...
Ice-3.2.1-VC80.msi ice安装包,支持vs2015
Ice-3.2.1-ThirdParty-VC80.msi ice第三方依赖包的windows安装程序
标题中的"Ice-3.4.2-rhel5-i386-rpm.tar.gz"是一个软件包的标识,其中"Ice"是软件的名称,3.4.2是该版本的版本号,"rhel5"表明这个软件包是为Red Hat Enterprise Linux 5(RHEL 5)设计的,"i386"表示它适用于32位...
zeroc_ice-3.7.6-cp38-cp38-win_amd64
ice-3.4.2-1.rhel6.noarch.rpm ice-libs-3.4.2-1.rhel6.i386.rpm ice-java-3.4.2-1.rhel6.noarch.rpm ice-java-devel-3.4.2-1.rhel6.i386.rpm ice-utils-3.4.2-1.rhel6.i386.rpm ice-servers-3.4.2-1.rhel6....
Ice-3.3.1-ThirdParty-VC80Ice-3.3.1-ThirdParty-VC80
《Ice-3.5.1 Demos:探索高效面向对象中间件的魅力》 在IT行业中,中间件扮演着至关重要的角色,它连接着各种应用程序,使得数据能够在不同的系统间顺畅流动。今天我们要聚焦的是名为Ice的中间件,一个现代、面向...
"ice-demos-3.6.4"这个压缩包文件很可能包含了zeroc ICE框架的3.6.4版本的一些示例和演示程序。这些演示通常是为了帮助开发者更好地理解ICE的工作原理,学习如何使用ICE进行通信和数据交换,以及如何利用其特性来...
Ice-3.6.2-WebInstaller
TRACE32、Open-ICE、Multi-ICE和Banyan-ICE是四种常见的集成电路测试与调试工具,广泛应用于嵌入式系统开发和硬件故障诊断。这些工具提供了强大的硬件级访问和控制,帮助工程师深入理解系统行为,提高产品开发效率。...
ice-demos-3.7.0是zeroc Ice的示例代码库,用于帮助开发者理解和学习如何使用这个框架。 Ice提供了丰富的功能,包括但不限于: 1. **跨平台性**:Ice支持多种操作系统,如Windows、Linux、macOS、Android和iOS等,...
1. 解压文件:首先,你需要将"Ice-3.5.1-third-party-solaris.tar.gz"解压到合适的目录,这通常会生成一个名为"Ice-3.5.1-ThirdParty-Solaris"的目录结构。 2. 配置环境:接着,你需要配置环境变量,例如设置ICE_...