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, IceIce.loadSlice("D:\\Java\\workspace\\workspace-temp\\test_ice\\slice\\myservice.ice")import demostatus = 0ice = Nonetry: 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 resultexcept: traceback.print_exc() status = 1if ic: # Clean up try: ic.destroy() except: traceback.print_exc() status = 1sys.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框架,支持跨平台.跨语言调用.它非常灵活 ...
随机推荐
- PostgreSQL 查看单表大小
1. 在数据库中查单个表 select pg_size_pretty(pg_relation_size('table_name')); 2. 查出并按大小排序 SELECT table_schema ...
- SpringMVC中url-pattern /和/*的区别
http://blog.csdn.net/u010648555/article/details/51612030
- Servlet技术 Cookie与Session
会话过程:用户打开浏览器,点击链接访问资源,最后到关闭浏览器的整个过程称之为会话. 会话使用:与服务器进行会话的过程中产生数据,数据被保存下来,服务器根据数据对客户进行辨别,做出个性化的响应. 介绍两 ...
- oracle查询相关语句
1,查询表空间使用情况select a.a1 表空间名称,c.c2 类型,c.c3 区管理,b.b2/1024/1024 表空间大小M,(b.b2-a.a2)/1024/1024 已使用M,subst ...
- python笔记十(列表生成式、字典生成式、生成器、生成器的并行)
一.列表生成式 列表生成式就是python设置的可以用来可以生成列表的. 如要生成一个0-9的列表我们可以通过以下代码实现: >>> list(range(10)) [0, 1, 2 ...
- Linux常见目录及命令介绍
一.Linux中常用的目录介绍: / -根目录 /bin -命令保存目录(普通用户亦可读取的命令) /boot -启动目录,启动相关文件 /d ...
- Java语言程序设计课程学期总结
2016-2017 第2学期 课程介绍 编程类课程,76学时(44理论+32实验),学期末还有1周的课程设计. 问题与现状 4个班共120人,教师无法逐一检查每个学生的编程实验. 纸质作业质量不高. ...
- Scheme r5rs letrec的用法
说明,这是r5rs的用法. (letrec ((<variable> <init>) ...) <body>) 假设((<variable> <i ...
- 异步请求引发的Chrome死锁
浏览器支持的并发异步请求数目是有限的,当需要的资源过多时候(远远大于并发数目),就需要自己管理XHR请求. 在实现自己的XHR的Manger时候,当请求数目达到2000多的时候,经常会遇到chrome ...
- 在一维坐标轴上有n个区间段,求重合区间最长的两个区间段。
//重叠区间数 #define N 2 typedef struct arrange { int x; int y; } Arrange; //先按左边界排序,若相等再按右边界排序(升序) int c ...