rpc 分两部份,一个是调用者,另一方是服务提供者

调用者只关心那个服务,传相应参数,返回内容就可以

而提供者根据调用相应服务同参数,工作处理后响应内容即可

根据他们的关系可以用JAVA 接口同实现类 来约束书写完成功能

 @QModel(1)
public interface ITestEnhance {
@QCommond(1)
public void a(double a); @QCommond(2)
public void b(float a); @QCommond(3)
public void c(byte a); @QCommond(4)
public void d(long a); @QCommond(5)
public void e(TestMessageObject obj); @QCommond(6)
public void f(AtomicLong al); @QCommond(7)
public TestMessageObject g(AtomicLong a,long b,TestMessageObject c);
}

接口

 public class TestEnhanceImpl implements ITestEnhance {

     @Override
public void a(double a) {
System.out.println("a接收到 数值 : " + a); } @Override
public void b(float a) {
System.out.println("b接收到 数值 : " + a); } @Override
public void c(byte a) {
System.out.println("c接收到 数值 : " + a);
} @Override
public void d(long a) {
System.out.println("d接收到 数值 : " + a);
} @Override
public void e(TestMessageObject obj) {
if (obj == null) {
return;
}
System.out.println("e接收到 数值 : " + SerialUtil.writeValueAsString(obj)); } @Override
public void f(AtomicLong a) {
System.out.println("f接收到 数值 : " + a.get());
} @Override
public TestMessageObject g(AtomicLong a, long b, TestMessageObject c) {
System.out.println("g接收到 数值 : " + a.get());
System.out.println("g接收到 数值 : " + b);
System.out.println("g接收到 数值 : " + SerialUtil.writeValueAsString(c));
return c;
}
public static void main(String[] args) {
ITestEnhance proxyObject = QRpcFactory.loadProxy(ITestEnhance.class,1L);
QRpcFactory.registerInvokeService(new TestEnhanceImpl()); proxyObject.a(-0.2);
proxyObject.b(0);
proxyObject.c((byte) 0x0);
proxyObject.c((byte) 0x1);
proxyObject.d((byte) 0x1); proxyObject.e(TestMessageObject.of());
proxyObject.f(new AtomicLong(-9)); proxyObject.e(null);
TestMessageObject obj=proxyObject.g(new AtomicLong(-11112), Long.MAX_VALUE, TestMessageObject.of());
SerialUtil.println(obj);
}
}

实现类

 /****
*
* @author solq
*/
public abstract class QRpcFactory {
private final static QRpcEnhanceService enhanceService = QRpcEnhanceService.getFactory(); public static <T> T loadProxy(Class<T> target, QNode... nodes) {
JavassistProxy.getDefault().register(target, enhanceService);
T ret = JavassistProxy.getDefault().transform(target);
IRpcContext ctx = (IRpcContext) ret;
ctx.setContext(RpcContext.of(nodes));
return ret;
} public static <T> T loadProxy(Class<T> target, long... ids) {
JavassistProxy.getDefault().register(target, enhanceService);
T ret = JavassistProxy.getDefault().transform(target);
IRpcContext ctx = (IRpcContext) ret;
ctx.setContext(RpcContext.of(ids));
return ret;
} public static void registerInvokeService(Object target) {
enhanceService.registerInvokeService(target);
}
}

rpc调用同注册工厂

 a接收到 数值 : -0.2
b接收到 数值 : 0.0
c接收到 数值 : 0
c接收到 数值 : 1
d接收到 数值 : 1
e接收到 数值 : {"start":1487901957121}
f接收到 数值 : -9
g接收到 数值 : -11112
g接收到 数值 : 9223372036854775807
g接收到 数值 : {"start":1487901957157}
{"start":1487901957157}

为什么要这样做?其实也可以用最原理的方式socket 或http 或JAVA 本身提供的rpc来做,自己做轮子跟使用轮子创造出来的价值是不能相比

处理做法上面说得很清楚,具体实现细节我在新书里会写出来,欢迎大家关注

最新文章

  1. UIImageView 自带动画+N张图片实现很炫的动画
  2. (C++) LNK2019: unresolved external symbol.
  3. 从0开始学Swift笔记整理(四)
  4. Sybase IQ导出文件的几种方式
  5. 《自学C语言》初级教程 - 目录
  6. URAL 1297 Palindrome 最长回文子串
  7. Properties操作
  8. BootStrap--模态框中 上传图片
  9. matlab求方差,均值,均方差,协方差的函数
  10. poj 1724 ROADS 最短路
  11. android第一天-------环境搭建
  12. shell 提取字符串
  13. 如何正确使用Java泛型
  14. CentOS7搭建Zookeeper环境
  15. miller——rabin判断素数
  16. ProtocolBuffer for Objective-C 运行环境配置及使用
  17. TP框架(接口文档模板框架)
  18. ZOJ 2314 - Reactor Cooling - [无源汇上下界可行流]
  19. 20170731xlVba根据数据表和模板表生成新表
  20. mac 下安装 express

热门文章

  1. OmniGraffle-新手指南
  2. UVa 11308 - Bankrupt Baker
  3. iOS 之 时间格式与字符串转换
  4. Python3基础 用 函数递归求解 一个数字的阶乘
  5. contextMenu,右键菜单
  6. file_get_contents无法请求https连接的解决方法
  7. Java 原型模式
  8. 如何在Visio 2007中画接口和实现类的关系图
  9. ZeroMQ 的模式
  10. CSS3-----图片翻页效果的展示