Zeroc Ice Slice语言使用 HelloWorld
Slice介绍
Range of Mapped Type |
Size of Mapped Type |
|
|
|
≥ 1bit |
|
-128-127 or 0-255 a |
≥ 8 bits |
|
-2 15 to 2 15 -1 |
≥ 16 bits |
|
-2 31 to 2 31 -1 |
≥ 32 bits |
|
-2 63 to 2 63 -1 |
≥ 64 bits |
|
IEEE single-precision |
≥ 32 bits |
|
IEEE double-precision |
≥ 64 bits |
|
All Unicode characters, excluding |
Variable-length |
其他类型
Range of Mapped Type |
Size of Mapped Type |
|
|
二进制数组 |
除了基本数据类型,还定义了复合数据类型:
第一个程序Hello World
1
2
3
4
5
6
7
|
[[ "java:package:com.my.demo" ]] module demo{ //module demo模块名,module和Java的Package是对应的,当前默认package是demo //如果需要生成和Java对应的package的话,在module上面新增[["java:package:com.my.demo"]]即可,包名为com.my.demo.demo interface MyService{ string hello(); }; }; |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
package service; import com.my.demo.demo._MyServiceDisp; import Ice.Current; public class MyServiceImpl extends _MyServiceDisp { private static final long serialVersionUID = 7114601588161119171L; @Override public String hello(Current __current) { return "Hello Jerome" ; //只是简单的返回 } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
package service; public class MyServiceStarter { public static void main(String[] args) { int status = 0 ; Ice.Communicator ic = null ; try { // 初始化Communicator对象,args可以传一些初始化参数,如连接超时,初始化客户端连接池的数量等 ic = Ice.Util.initialize(args); // 创建名为MyServiceAdapter的ObjectAdapter,使用缺省的通信协议(TCP/IP端口为10001的请求) Ice.ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints( "MyServiceAdapter" , "default -p 10001" ); // 实例化一个MyService服务对象(Servant) MyServiceImpl servant = new MyServiceImpl(); // 将Servant增加到ObjectAdapter中,并将Servant关联到ID为MyService的Ice Object adapter.add(servant, Ice.Util.stringToIdentity( "MyService" )); // 激活ObjectAdapter adapter.activate(); // 让服务在退出之前,一直持续对请求的监听 System.out.println( "server is started ... " ); ic.waitForShutdown(); } catch (Exception e) { e.printStackTrace(); status = 1 ; } finally { if (ic != null ) { ic.destroy(); } } System.exit(status); } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
package client; import com.my.demo.demo.MyServicePrx; import com.my.demo.demo.MyServicePrxHelper; public class MyClient { public static void main(String[] args) { int status = 0 ; Ice.Communicator ic = null ; try { // 初始化通信容器 ic = Ice.Util.initialize(args); // 传入远程服务单元的名称、网络协议、IP及端口,构造一个Proxy对象 Ice.ObjectPrx base = ic.stringToProxy( "MyService:default -p 10001" ); // 通过checkCast向下转型,获取MyService接口的远程,并同时检测根据传入的名称获取服务单元是否OnlineBook的代理接口 MyServicePrx prxy = MyServicePrxHelper.checkedCast(base); if (prxy == null ) { throw new Error( "Invalid proxy" ); } // 调用服务方法 String rt = prxy.hello(); System.out.println(rt); } catch (Exception e) { e.printStackTrace(); status = 1 ; } finally { if (ic != null ) { ic.destroy(); } } System.exit(status); } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#!/usr/bin/env python # ********************************************************************** # # Copyright (c) 2003-2013 ZeroC, Inc. All rights reserved. # # This copy of Ice is licensed to you under the terms described in the # ICE_LICENSE file included in this distribution. # # ********************************************************************** import sys, traceback, Ice Ice.loadSlice( "D:\\Java\\workspace\\workspace-temp\\test_ice\\slice\\myservice.ice" ) import demo status = 0 ice = None try : ic = Ice.initialize(sys.argv) base = ic.stringToProxy( "MyService:default -p 10001" ) printer = demo.MyServicePrx.checkedCast(base) if not printer: raise RuntimeError( "Invalid proxy" ) result = printer.hello() print result except : traceback.print_exc() status = 1 if ic: # Clean up try : ic.destroy() except : traceback.print_exc() status = 1 sys.exit(status) |
参考
资料
Zeroc Ice Slice语言使用 HelloWorld的更多相关文章
- ICE:slice语言常识整理
ICE:Slice语言(二)--源文件和词法规则: 文件命名 Slice的源文件以.ice为扩展名. 对于大小写不区分的系统(例如DOS),文件的扩展名可以大写,也可以小写,例如Cli ...
- ICE学习第三步-----Slice语言
ICE:Slice语言(一)-编译 Introduce简介 Slice(Specification language for ice)是分离对象和对象的实现的基础的抽象机制.Slice在客户端和服务器 ...
- ZeroC ICE的远程调用框架 Slice如何帮助我们进行Ice异步编程(AMI,AMD)
Slice最大的用处就是为我们使用Ice进行编程,代劳绝大部分的重复性代码,并提供一些帮助性的框架代码,如用于AMI和AMD方式进行异步编程的回调框架. 当Slice不为我们生成代码时,我们仍然可以按 ...
- ZeroC Ice 暂记
摘自: http://weibo.com/p/1001603869896789339575 原文地址: http://www.oschina.net/question/865233_242146 吴治 ...
- ZEROC ICE 跨平台间程序调用 java版
前言: 本来建博客是为了和大家分享一些前端的开发经验和心得呢,但是阴差阳错,第一篇技术博客确实关于跨平台,跨语言服务端调用的解决方案---ZEROC ICE. 最近一个项目涉及到java.python ...
- Zeroc Ice原理介绍
Ice介绍 Ice(Internet Communications Engine)是ZeroC公司的杰作,继承了CORBA的血统,是新一代的面向对象的分布式系统中间件.Ice是RPC通 ...
- Zeroc Ice开发环境搭建
搭建Ice环境 1. Linux(推荐,更接近真实生产环境) 2. Windows(方便学习开发) 下载安装包:https://zeroc.com/downloads (百度网盘链接:http ...
- Ubuntu16.04下ZeroC ICE的安装与使用示例(Qt C++ 和 Java)
项目需求:在Ubuntu16.04系统下安装并使用ICEgrid 3.7进行c++和Java Springboot开发环境的通信,下面逐一介绍各个步骤的详解: 一:Ice Lib的安装 参考官网地址: ...
- 用Python开发Zeroc Ice应用
Zeroc Ice简介 Zeroc ICE(Internet Communications Engine ,互联网通信引擎)是目前功能比较强大和完善的RPC框架,支持跨平台.跨语言调用.它非常灵活 ...
随机推荐
- python3全栈开发-并发编程的多进程理论
一. 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行): duoduo在一个时间段内有很多任务要做:python备课的任务,写 ...
- rsync 系统用户/虚拟用户 备份web服务器数据及无交互定时推送备份
一.服务环境 (1),WEBserver(192.168.10.130) : BACKserver(192.168.10.129) (2),BACKserver服务器部署,安装所需软件,并启动 (3) ...
- Linux常用命令大全(归类)
最近都在和Linux打交道,这方面基础比较薄弱的我只好买了本鸟哥的书看看,感觉还不错.我觉得Linux相比windows比较麻烦的就是很多东西都要用命令来控制,当然,这也是很多人喜欢linux的原因, ...
- Linux学习之CentOS(二十)------vi/vim 按键说明
vi/vim 按键说明 除了上面简易范例的 i, Esc, :wq 之外,其实 vim 还有非常多的按键可以使用. 第一部份:一般模式可用的光标移动.复制粘贴.搜索替换等 移动光标的方法 h 或 向左 ...
- form submit提交
form内控件参数自动添加到url后,而自定义的url参数则不能添加到url后 $('#fm').form('submit', { url: 'Data/Diary.ashx?dt=' + new D ...
- JMQ
[京东技术]京东的MQ经历了JQ->AMQ->JMQ的发展,其中JQ的基于关系数据库,严格意义上讲称不上消息中间件,JMQ的存储是JFS和HBase,AMQ即ActiveMQ,本文说说JM ...
- python if判断语句&计算
python对缩进要求严格,代码块里的缩进必须一样,可以常用 tab键 表示4个空格 if 条件: 代码块 else: if判断语句如下: 1 print("吃饭,喝水,回家") ...
- Minimize the error CodeForces - 960B
You are given two arrays A and B, each of size n. The error, E, between these two arrays is defined ...
- Docker 数据卷
数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS,可以提供很多有用的特性: 数据卷可以在容器之间共享和重用 对数据卷的修改会立马生效 对数据卷的更新,不会影响镜像 卷会一直存在,直到没有容 ...
- Python3 编程第一步
现在,我们能使用Python完成比 2+2 更复杂的工作.在下例里,我们能写出一个初步的斐波纳契数列如下: >>> # Fibonacci series: 斐波纳契数列 ... # ...