介绍书中人物(笼中月介绍)

远程对象的基础接口,是一个为了在执行进程中和进程间调用时的高性能,而设计的轻量级远程调用机制的核心部分。这个接口描述了和远程对象交互的抽象协议。不要直接实现这个接口,而是通过继承 Binder来实现。IBinder的关键API是与 Binder.onTransact() 相匹配的transact() .这个方法分别允许你给IBinder对象发出一个请求,并接收一个进入一个Binde

大家好,又见面了,我是你们的朋友全栈君。

 远程对象的基础接口,是一个为了在执行进程中和进程间调用时的高性能,而设计的轻量级远程调用机制的核心部分。这个接口描述了和远程对 象交互的抽象协议。不要直接实现这个接口,而是通过继承 Binder来 实现。

IBinder的关键API是与 Binder.onTransact() 相匹配的transact() .这个方法分别允许你给IBinder对象发出一个请求,并接收一个进入一个Binder对象的请求。这个事务API是同步的,这样一个对transact() 的调用会在目标从Binder.onTransact()返 回后自己才能返回;这是在调用一个存在于本地进程对象的预期行为,并且潜在的IPC(进程间通信机制)也在进程间切换时确保这些相同语义得到应用。  

通过transact()送出的数据是一个 Parcel, 一个通常的数据缓冲器,并且包含一些关于他内容的元数据。这些元数据用来在缓冲期内管理IBinder对象的引用,以至于那些引用可以在缓冲器穿越进程时 被包含进来。这个机制可以确保了当一个IBinder被写入一个Parcel被传送给其他进程时,如果其他进程返回给原先进程同样的IBinder引用, 原 先的进程接收同样的IBinder对象。这些语义允许IBinder/Binder对象被用作进程间切换时管理的唯一的身份(作为一个标志或其他目的来服 务)。

系统在每一个事务线程运行的进程里维护了一个事务线程池。这些线程用来分发所有来自其他进程的IPCs。例如,当一个IPC从A进程到 B进程被建立,在A里的调用线程用transact()向进程B发出一个事务。在B中下一个有效的线程池接收到进入的事务,对目标对象调用 Binder.onTransact(),并且用结果Parcel回复。在接收到结果时,在进程A中的线程返回以允许进程继续执行。效果上,其他进程看起 来象作为那些你没有在自己进程中创建执行的额外线程而使用的。

Binder系统也支持进程间的递归调用。例如,如果进程A执行一个到进程B的事务,并且进程B在处理这个事务时对一个在A里实现的 IBinder调用transact(),然后在A里的正在等待原先事务结束的线程,将会关心对被B调用的对象调用Binder.onTransact ().这个就确保在调用远程binder对象时的递归语义和调用本地对象时是一样的。

当和远程对象打交道时,你经常想要找出何时他们不再有效。下面有三条可以被确定的方式:

IBinder - 东东 - 东东的博客 嵌套类

IBinder.DeathRecipient 当服务一个 IBinder的进程消失后接收一个回调的接口。

IBinder - 东东 - 东东的博客 了解间接子类

请参阅

概要

常量

      Value  
int  DUMP_TRANSACTION  IBinder事务协议码: 清除内部状态  1598311760  0x5f444d50 
int  FIRST_CALL_TRANSACTION  用户指令的第一个事务码可用。 0x00000001 
int  FLAG_ONEWAY   transact(int, Parcel, Parcel, int)标志符: 这是一个单向调用,意味着调用者会立即返回,而不等待从被调用者那里的结果。 0x00000001 
int  INTERFACE_TRANSACTION  IBinder事务协议码: 向事务接收端询问他的规范接口描述符。 1598968902  0x5f4e5446 
int  LAST_CALL_TRANSACTION  用户指令的最后一个事务码可用。 16777215  0x00ffffff 
int  PING_TRANSACTION  IBinder事务协议码: pingBinder().  1599098439  0x5f504e47 

公共方法

          String  getInterfaceDescriptor()

获得被这个binder支持的接口的规范名字。
          boolean  isBinderAlive()

检查binder所在的进程是否还是存在的。
          void  linkToDeath(IBinder.DeathRecipient recipient, int flags)

如果这个binder消失,为标志信息注册一个接收器。
          boolean  pingBinder()

检查是否这个对象还存在。
          IInterface  queryLocalInterface(String descriptor)

试图获得一个对这个Binder对象的一个接口的本地实 现。
          boolean  transact(int code, Parcel data, Parcel reply, int flags)

用对象执行一个一般的操作。
          boolean  unlinkToDeath(IBinder.DeathRecipient recipient, int flags)

清除一个之前注册的死亡标识信息。

内容常量

public static final int DUMP_TRANSACTION

IBinder事务协议码: 清除内部状态 

常 量值: 
1598311760 (0x5f444d50)


public static final int FIRST_CALL_TRANSACTION

用户指令的第一个事务码可用

常 量值: 
1 (0x00000001)


public static final int FLAG_ONEWAY

transact(int, Parcel, Parcel, int)标志符:这是一个单向调用,意味着调用者会立即返回,而不等待从被调用者那里的结果。

常 量值: 
1 (0x00000001)


public static final int INTERFACE_TRANSACTION

IBinder事务协议码: 向事务接收端询问他的规范接口描述符。

常 量值: 
1598968902 (0x5f4e5446)


public static final int LAST_CALL_TRANSACTION

用户指令的最后一个事务码可用。

常 量值: 
16777215 (0x00ffffff)


public static final int PING_TRANSACTION

IBinder事务协议码: pingBinder(). 

常 量值: 
1599098439 (0x5f504e47)

公共方法

public 
String getInterfaceDescriptor()

获得被这个binder支持的接口的规范名字。


public boolean isBinderAlive()

检查binder所在的进程是否还是存在的。

返回值

  • 如果进程不能在则返回假值。注意如果返回真值,进程可能在调用返回时已经死掉了。


public void linkToDeath(
IBinder.DeathRecipient recipient, int flags)

如果这个binder消失,为标志信息注册一个接收器。如果这 个binder对象不正常的消失(比较典型是因为他的服务进程已经被终止)那么这个给定的 
IBinder.DeathRecipient
DeathRecipient.binderDied()方 法将会被调用。

你将仅仅从远程binders那里接收到一个死亡标识信息,作为定义中的本地的binders在调用死亡前是不会死亡的。

异常


RemoteException 如果目标IBinder的进程已经死亡。
RemoteException


public boolean pingBinder()

检查是否这个对象还存在。

返回值

  • 如果服务进程已经消失则返回假值,否则结果被pingBinder()在另一边实现返回(通常默认的是真值)。


public 
IInterface queryLocalInterface(
String descriptor)

试图获得一个对这个Binder对象的一个接口的本地实现。如 果返回NULL,你将需要去实例化一个代理类来通过transact()方法对调用编组。


public boolean transact(int code, 
Parcel data, 
Parcel reply, int flags)

用对象执行一个一般的操作。

参数

code 执行的行为. 这将会是一个在 FIRST_CALL_TRANSACTION 和 LAST_CALL_TRANSACTION之 间的数字。
data 发送给目标的编组后的数据,通常不是null。如果你不传送任何数据,你必须在创建一个空的Parcel放在这里。
reply 来自目标被接收的编组后的数据。如果你对返回值不感兴趣可能返回null。
flags 额外的操作符。0是通常意义的RPC,或者 FLAG_ONEWAY 表示一个单向RPC.



public boolean unlinkToDeath(
IBinder.DeathRecipient
 recipient, int flags)
清除一个之前注册的死亡标识信息。如果这个对象已经死亡,这个 接收器将不再被调用。

返回值

  • 如果接收器成功被断开连接则返回真,你必须确保他的 DeathRecipient.binderDied() 方法没有被调用。如果目标IBinder已经死亡则返回假值,意味着这个方法已经(或将要)被调用。

异常


NoSuchElementException 如果给定的接收器还没有和IBinder注册,并且这个IBinder还活着。注意如果接收器从来没有被注册过,但是IBinder已经死亡,这个异常将 不会抛出,你会接收到一个假值作为返回值。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128838.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月15日 下午5:00
下一篇 2022年4月15日 下午5:00


相关推荐

  • idea2022.2.4激活码(JetBrains全家桶)

    (idea2022.2.4激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月30日
    917
  • 最常用三极管导通电路

    最常用三极管导通电路

    2022年6月15日
    30
  • phpMyAdmin访问远程MySQL数据库的方法

    phpMyAdmin访问远程MySQL数据库的方法

    2021年9月19日
    36
  • 云原生—Gradle和Maven性能对比及技术选型

    云原生—Gradle和Maven性能对比及技术选型而 Groovy 也是一种基于 JVM 的敏捷开发语言 它结合了 Python Ruby 和 Smalltalk 的许多强大的特性 Groovy 代码能够与 Java 代码很好地结合 也能用于扩展现有代码 同时因为守护进程是一个一直运行的进程 除了可以避免每次 JVM 启动的开销之外 还可以缓存项目结构 文件 task 和其他的信息 从而提升运行速度 场景虽然在一个项目中包含所有代码的情况很少见 但多模块构建的情况很常见 其中大部分代码位于一个或几个比其他模块大得多的模块中 但如果是大中型项目 这种构建效率就能更有体会了

    2026年3月18日
    2
  • SpringBoot 线程池

    SpringBoot 线程池SpringBoot线程池简介使用开启配置使用SpringBoot默认线程池@Async自定义线程池扩展ThreadPoolTaskScheduler和ThreadPoolTaskExecutor继承关系结构Reject策略预定义总结简介程序、线程和线程池进程是资源分配最小单位,线程是程序执行的最小单位。计算机在执行程序时,会为程序创建相应的进程,进行资源分配时,是以进程为单位进行相应的分配。每个进程都有相应的线程,在执行程序时,实际上是执行相应的一系列线程。总结:进程是资源分配最小单位,线程

    2022年6月29日
    143
  • JAVA map排序实现

    JAVA map排序实现Map排序的方式有很多种,这里记录下自己总结的两种比较常用的方式:按键排序(sortbykey),按值排序(sortbyvalue)。1、按键排序jdk内置的java.util包下的TreeMap<K,V>既可满足此类需求,向其构造方法TreeMap(Comparator<?superK>comparator)传入我们自定义的比较器即可实…

    2022年7月15日
    20

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号