Aidl 基础其二 Server和Client互相交互
来源:互联网 发布:java生成随机数的方法 编辑:程序博客网 时间:2024/06/09 15:40
AIDL交互示意图
Aidl :大致实现思路是,在主程序A中定义一个Aidl文件C.aidl,目的是让其他程序B得到C的对象的引用,让后通过C中定义的方法,来操控A,就是单方向操控;C是一个aidl文件,其中定义的方法都是没有实现的,那么在A中定义一个Servce S,在S中创建一个类CStub继承C.Stub并实现这些方法,在Servce S的onBind方法中返回一个CStub的实例,那么其他程序B就可以在连接Servce S时通过
public voidonServiceConnected(ComponentName name, IBinder service) {
IMyAidlInterface stub = IMyAidlInterface.Stub.asInterface(service);
try{
Article article = stub.getFirstNovel();
Log.i("","-->article: "+article.toString());
} catch(RemoteException e) {
e.printStackTrace();
}
}
得到CStub,即可操控A了那么A中如何操控B呢,所以我们定义了另外一个aidl,extendo.aidl,其中定义了一些方法;在ServerDo.aidl中提供两个方法,绑定(registerCallback)和解绑(unRegisterCallback)extenddo;这两个方法在哪里调用呢,当B连接Servce成功时和断开连接是分别调用,当然肯定要在B中创建一个类继承ExtendDo.Stub并实现里面的方法;这样,在程序A中得到了B中实现的类的对象我们就可以操控B了
代码结构
这里的LetMainDo即ServerDo,CallBack即ExtendDo,MainService即RadioDoService
阅读全文
0 0
- Aidl 基础其二 Server和Client互相交互
- client-server交互计算器-client端/Windows
- AIDL跨进程回调(Server回调Client)
- client-server交互计算器-server端/Windows
- C++ Socket编程 基础一:简单的server 和client
- Client与Server交互的错误信息
- canal client -->canal server 的交互过程
- 深入浅出 Redis client/server交互流程
- 深入浅出 Redis client/server交互流程
- ZigBee server和 client
- Android跨进程通信-AIDL详解示例(client+server)
- MVC中的V和C互相交互
- 介绍---memory和client/server
- 网络编程client和server
- Onvif开发server和client
- JVM -server和-client模式
- jvm的client和server
- NIO 实现server和client
- UITextField只显示一定长度
- Spring Cloud源码分析(一)Eureka
- web.xml 字符编码过滤器
- JAVA Pattern and Matcher
- Spring Boot中使用RabbitMQ
- Aidl 基础其二 Server和Client互相交互
- behaviac使用总结
- Spring Cloud构建微服务架构(四)分布式配置中心(续)
- Android Studio 第一个JNi工程
- Spring Cloud构建微服务架构(七)消息总线
- ubuntu Java环境配置
- Spring Cloud构建微服务架构(七)消息总线(续:Kafka)
- 【总结】CTR预估中GBDT与LR融合方案
- Spring Cloud源码分析(二)Ribbon