Android | IPC进程间通信 之 AIDL实践

简介: Android | IPC进程间通信 之 AIDL实践

项目GitHub地址

Service基础回顾

  • **主要要用到的就是启动Service和绑定Service两种方式,

大概的流程这里就不赘述了,
可以参考一下这篇博文:学习笔记| AS入门(十) 组件篇之Service**

  • 这里主要强调几点:

    • **startServicebindService都可以启动服务,

但是其影响Service的生命周期不同,
而且bindService可以是Activity能同Service交互通信,
监控Service任务的情况;**

- **`startService`和`bindService`两种方式都调用之后,

必须同时使用stopServiceunbindService
才能销毁服务;**

- **换句话说,

startService被调用之后,如果没有调用stopService
则无论调用多少次bindServiceunbindService
都无法销毁服务;**


IPC实战

跨进程启动服务

**现在我们看一下这两个实战项目,
一个[AIDLTest项目](),
还有一个[AIDLDemo项目](),

AIDLTest项目可以
单独用于测试同一个进程内的Service基础运作,

当然这里咱们要表演一个IPC(进程间通信)过程,
即,
AIDLDemo项目中,
访问到AIDLTest项目MyService
【即跨APP、跨进程通信访问】

下面是AIDLTest项目AndroidManifest
我们给MyService一个action标签
以及记下来AIDLTest项目的包名,待会儿需要用到!
AIDLTest项目的MyService代码:**

public class MyService extends Service {
    ....
    @Override
    public void onCreate() {
        super.onCreate();
        Log.e("MyService","服务创建了");
...
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        Log.e("MyService","服务启动了");
        return super.onStartCommand(intent, flags, startId);
    }
...
    @Override
    public IBinder onBind(Intent intent) {
        Log.e("MyService","服务绑定了");
        return mb;
    }
    ...

    @Override
    public boolean onUnbind(Intent intent) {
        Log.e("MyService","服务解绑了");
        return super.onUnbind(intent);
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        Log.e("MyService","服务销毁了");

    }
}

**AIDLDemo项目中,
指定访问我们刚刚提到的AIDLTest项目的包名
以及MyService的action标签:**

  • **成了,先运行AIDLTest项目【提供Service方】,

再运行AIDLDemo项目【访问方】,
AIDLDemo项目中点击按钮,观察logcat,
可以看到我们在AIDLDemo项目中操作的时候,
成功跨进程开启了另外一个进程APP【AIDLTest】的Service了!!!**

跨进程绑定服务

AIDL实战开始!!

  • **以上的方式只能做到跨进程开启、绑定服务,

但是无法进行通信,监控另一个进程的进度;
所以这里就要使用AIDL了!**

  • **AIDL是作为

两个进程间 数据共享的接口!**

一般性步骤

  • **创建aidl文件,

【aidl文件用于定义进程间的接口,
进程两端的文件要保持一致】;**

  • **创建好了AIDL文件之后,

build一下会自动生成java文件;**

  • 使用AIDL;

  • **1/3

创建aidl文件,
服务提供方先创建,即 AIDLTest项目
在对应的包处 new 一下就好了:
在弹出的窗口处点击Finish后,成功创建,
项目会自动生成一个包:

【刚刚是右键aidltest包创建的AIDL文件,
所以这里生成的包跟aidltest包的完整包名是一致的】
初始生成的AIDL文件 —— IMyAidlInterface.aidl:**

// IMyAidlInterface.aidl
package com.lwp.aidltest;

// Declare any non-default types here with import statements

interface IMyAidlInterface {
    /**
     * Demonstrates some basic types that you can use as parameters
     * and return values in AIDL.
     */
    void basicTypes(int anInt, long aLong, boolean aBoolean, float aFloat,
            double aDouble, String aString);
}
  • 添加自定义的业务方法【需要提供给其他进程使用的业务】:
...
interface IMyAidlInterface {
    ...
            
    //定义自己所需要的方法:显示当前服务的进度
    void showProgress();        
}
  • **2/3

build一下项目:
可以看到项目build/generated/下生成了aidl相关的包
(generated包表示该包下放着的都是自动生成的代码),
展开之后可以看到自动生成的java文件:**
**注意这里生成的是java文件
我们刚刚自定义的文件是aidl文件,并不能直接使用

稍微浏览一下生成的java文件,
可以看到它首先定义了一个静态抽象类Stub!!!!!!!!!
Stub类 继承Binder类,表明通信作用
Binder类是实现IBinder接口的;public class Binder implements IBinder
所以Stub类也间接实现了IBinder接口)!!!!!!!
同时它实现了我们刚刚自定义的aidl文件(接口)!!!!!!!!!:
我们自定义的aidl文件中的接口方法,
在生成的这个接口中,都会有两个方法对应,
第一个是重写(override)的,第二个是重新生成的声明:
**

**3/3
使用AIDL!!!
调用的核心,就是使用刚刚我们提到静态内部抽象类stub!!!!
(即,我们最终使用的接口类,!!!!!
是AS自动生成的aidl文件接口对应的java接口类!!!!!!!!!)
AIDLTest项目 中的MyServiceonBind方法中,
返回刚刚build生成aidl文件接口对应的java接口类实例
匿名内部类的形式实现业务方法!!!!!!!
(非跨进程情况,这里返回的是自定义Service类 内部自定义的Binder类
下面是使用aidl接口后,
!!!!!!!!!!!!!
提供服务本线程内调用服务方法的写法!!!!!!!!!!!!!
!!!!!!!!!!!!!:接着运行项目,
点击启动服务,接着点击绑定服务,测试成功:**

接着是另外一个进程提供服务进程服务跨进程调用的写法

  • **上面说了,

IPC两边的进程准备的AIDL文件都需要保持一致
所以接下来,
AIDLDemo项目创建一个aidl包
aidl包创建一个包用于存放AIDL文件
这个用于存放AIDL文件的包的包名需要跟
服务提供方【AIDLTest项目】存放aidl文件的包名保持一致!!!!!!
接着把 AIDLTest项目中的AIDL文件
直接复制粘贴、覆盖到AIDLDemo项目中的aidl包下对应的包下:
**

  • **Rebuild一下AIDLDemo项目,自动生成Java代码,

因为使用的AIDL文件跟AIDLTest项目的一样,
所以生成的文件也都是一样:**

  • 接着使用AIDL接口:
  • **运行两个项目,然后在AIDLDemo项目的APP上操作,

可以看到AIDLTest项目是有对应的响应的,
即,实现跨进程调用服务方法:**

  • **注意,

这里使用AIDL是可以方便生成IPC所需的接口代码,
但是其实读懂自动生成的Java接口文件,
懂得其中的IPC编程规范,要自己编写而不用AIDL文件也是可以的;
AIDL文件只是方便我们自动生成代码工具
真正使用的以及实现跨进程逻辑的,
是AS根据AIDL文件自动生成Java接口文件!!!!**






参考:慕课网

相关文章
|
算法 调度 UED
探索操作系统中的进程调度:理论与实践
【9月更文挑战第24天】 在数字世界的心脏跳动着的是操作系统,它像一位精明的指挥家,精心安排每个音符的演奏。本文将带你进入操作系统的内核,一探进程调度的秘密。我们将从简单的批处理系统谈起,穿越时间隧道,见证现代多道程序设计系统的复杂性与优雅。你将看到代码如何赋予理论以生命,理解调度算法背后的哲理。让我们一起跟随甘地的指引,成为我们希望在世界上看到的改变。
|
弹性计算 运维 监控
基于进程热点分析与系统资源优化的智能运维实践
智能服务器管理平台提供直观的可视化界面,助力高效操作系统管理。核心功能包括运维监控、智能助手和扩展插件管理,支持系统健康监控、故障诊断等,确保集群稳定运行。首次使用需激活服务并安装管控组件。平台还提供进程热点追踪、性能观测与优化建议,帮助开发人员快速识别和解决性能瓶颈。定期分析和多维度监控可提前预警潜在问题,保障系统长期稳定运行。
562 17
|
消息中间件 存储 Linux
|
消息中间件 程序员 数据处理
探究操作系统中的进程间通信(IPC)机制及其在现代软件开发中的应用
本文深入探讨了操作系统中的核心概念——进程间通信(IPC),揭示了其在现代软件开发中的关键作用。通过对各种IPC机制如管道、消息队列、共享内存等的详细分析,本文旨在为读者提供一个清晰的理解框架,帮助他们掌握如何在实际应用中有效利用这些技术以实现进程间的协同工作。此外,文章还将探讨IPC在高并发环境下的性能优化策略,以及如何避免常见的IPC编程错误。通过结合理论与实践,本文不仅适合希望深入了解操作系统原理的技术人员阅读,也对那些致力于提升软件质量和开发效率的程序员具有重要参考价值。
486 13
|
消息中间件 Linux API
Linux c/c++之IPC进程间通信
这篇文章详细介绍了Linux下C/C++进程间通信(IPC)的三种主要技术:共享内存、消息队列和信号量,包括它们的编程模型、API函数原型、优势与缺点,并通过示例代码展示了它们的创建、使用和管理方法。
456 0
Linux c/c++之IPC进程间通信
|
消息中间件 存储 网络协议
操作系统的心脏:深入理解进程间通信(IPC)机制
在现代计算机系统中,操作系统扮演着至关重要的角色,而进程间通信(IPC)作为操作系统的核心功能之一,极大地影响着系统的性能和稳定性。本文将通过浅显易懂的语言,详细探讨进程间通信的基本原理、主要类型及其实际应用,旨在为读者提供一个清晰且全面的理解和认识。 ##
1030 1
|
Java Android开发 数据安全/隐私保护
Android中多进程通信有几种方式?需要注意哪些问题?
本文介绍了Android中的多进程通信(IPC),探讨了IPC的重要性及其实现方式,如Intent、Binder、AIDL等,并通过一个使用Binder机制的示例详细说明了其实现过程。
1113 4
|
消息中间件 Python
深入理解操作系统的进程间通信(IPC)机制
本文将探讨操作系统中的核心概念——进程间通信(IPC),揭示其在系统运作中的重要性及实现方式。通过分析不同类型的IPC手段,如管道、信号、共享内存等,帮助读者更好地理解操作系统的内部工作原理及其在实际应用中的表现。
792 1
|
消息中间件 存储 大数据
深入理解操作系统中的进程间通信(IPC)机制
本文旨在探讨操作系统中进程间通信(IPC)的核心机制与其重要性。通过对不同IPC手段如管道、信号、消息队列及共享内存等的详细解析,揭示它们如何高效地促进进程间的信息交换与同步。文章不仅阐述各种IPC技术的实现原理,还探讨了它们在实际系统应用中的场景与优化策略,为系统开发者提供全面而深入的理解。
|
消息中间件 Unix
操作系统的心脏:深入理解进程间通信(IPC)
在现代计算中,操作系统扮演着至关重要的角色,它不仅管理着硬件资源,还负责协调和优化应用程序之间的交互。本文将深入探讨操作系统中的一个核心概念——进程间通信(IPC),揭示其背后的机制以及在实际应用中的重要性。通过通俗易懂的语言和条理清晰的解释,本文旨在为读者提供一个关于IPC的全面了解,从基本定义到高级应用,带领大家走进操作系统的神秘世界。

热门文章

最新文章

下一篇
开通oss服务