社区首页 >问答首页 >我应该在什么时候使用Android的每种不同的消息类型?

我应该在什么时候使用Android的每种不同的消息类型?
EN

Stack Overflow用户
提问于 2009-05-28 11:43:29
回答 4查看 3.3K关注 0票数 5

我使用Android已经一年多了,但是我仍然很难决定什么时候应该在进程/线程之间使用不同类型的消息传递/通信。我主要讨论广播意图,使用services的AIDL,使用处理程序发送消息和套接字通信。

这些工具中的许多都可以用来完成类似的任务,但是哪种工具更适合特定的情况?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2009-06-03 13:44:17

这是一个相当开放的问题,但让我试着描述一下我如何看待应用程序内/应用程序间通信的最佳工作方式。

Android消息传递的一个关键方面是所有应用程序组件都是松散绑定的概念。由于所有应用程序都在单独的进程中运行,并且一个“应用程序”实际上可能由几个应用程序(负责提供不同的活动或服务)组成,因此消息传递技术完全基于跨进程边界编组消息的思想。

意向

作为消息传递的首选技术,只要可能,总是尝试使用意图。这是在Android中传输消息的最“原生”方式。

优势

使用Intents进行消息传递维护了应用程序组件的松散绑定,使您可以在多个应用程序之间无缝地传输消息。意图在核心系统中大量使用,用于启动活动和服务,以及广播和接收系统事件。

使用extras Bundles,您可以将原语的键/值对作为意图中的有效负载数据,以便轻松地将信息从一个应用程序组件传递到另一个应用程序组件-即使这些组件运行在不同的进程中。

缺点

因为意图被设计为在进程之间传递,所以附加负载仅支持原语类型。如果您需要使用Intent发送对象,则需要在一端将其解构为原语,并在另一端重新构造它。

应用程序类

如果您只想在单个进程中运行的单个应用程序中进行通信,这是一个方便的解决方案。

优势

通过扩展Application类(并将其实现为单例),您可以获得一个只要存在任何应用程序组件就会存在的对象,从而为在应用程序组件之间存储和传输复杂的对象数据提供了一个集中的位置。

缺点

此技术将消息传递限制到单个应用程序中的组件。

服务绑定、进程间通信和AIDL

绑定到服务允许您访问其方法并与其交换对象。AIDL是一种定义如何将对象序列化为操作系统原语的方法,以便在绑定到的服务在单独的应用程序中运行时,可以跨进程边界对其进行编组。

优势

当您绑定到服务时,您可以访问它,就像它是调用类中的对象一样。这意味着您可以在Service上执行方法,并与其交换富对象。

请注意,如果您绑定到不同应用程序进程中的服务,则需要创建AIDL定义,告诉Android如何序列化/反序列化您希望在应用程序之间传递的任何对象。

缺点

为IPC创建AIDL类是一项额外的工作,而绑定在服务和活动之间创建了额外的依赖关系,这可能会使内核在其他应用程序处于匮乏状态时更难清理资源。

不过,跨进程边界封送消息的代价很高。因此,如果你不是在服务上执行方法,使用绑定和IPC可能是大材小用--看看你是否可以使用Intents实现同样的事情。

套接字

如果你求助于套接字来在单个设备上运行的应用程序内部或之间进行通信,这要么是因为没有其他方式,要么是因为你错过了某个技巧。如果您的消息正在离开设备,那么套接字是一个很好的、快速的替代方案。如果你停留在设备上,很可能是有意的,或者IPC将是一个更好的选择。

票数 16
EN

Stack Overflow用户

发布于 2015-06-09 14:36:14

这完全取决于您的应用程序的用例和类型。如果应用程序一直在运行,最好使用AIDL方法,因为这是最安全的通信方式。如果应用程序不需要一直运行,那么您可以使用广播意图或挂起意图方法在应用程序之间进行通信。

票数 2
EN

Stack Overflow用户

发布于 2009-05-29 10:05:36

我的2分

  • 我没有使用过本地套接字。因为您必须生成和解析数据,所以这看起来有点过头。GUI用于其他应用程序可能想要做的事情(在编写窗口中启动我,或者选择一些out)
  • AIDL/Parcels/Handlers,用于让
  • 与不断运行的无头进程对话。根据应用程序的不同,许多实际的数据传输可能会使用内容提供商,但我倾向于有一些数据需要在该通道之外传输。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/922819

复制
相关文章
MySQL 子查询 嵌套查询
意思就是内层的select查到了(至少查到了一行)才进行查询,没有查到就不进行查询。
宁在春
2022/10/31
12.1K0
mysql中多表嵌套查询例子_mysql子查询嵌套规则
MySQl从4.11版后已经完全支持嵌套查询了,那么下面举些简单的嵌套查询的例子吧(源程序来自MySQL User Manual):
全栈程序员站长
2022/11/01
3.4K0
MySQL 嵌套查询_嵌套查询和嵌套结果的区别
where course.cno=sc.cno and course.cname=’数据库’ and grade>=80)[/code](3)查询计算机系最高成绩。
全栈程序员站长
2022/09/22
4.3K0
MySQL——优化嵌套查询和分页查询
嵌套查询(子查询)可以使用SELECT语句来创建一个单列的查询结果,然后把这个结果作为过滤条件用在另一个查询中。嵌套查询写起来简单,也容易理解。但是,有时候可以被更有效率的连接(JOIN)替代。
撸码那些事
2018/10/08
2.9K0
MySQL——优化嵌套查询和分页查询
mysql嵌套子查询的应用
sql语句中一个查询有时未必能满足需求,应对多表联查时就需要进行嵌套查询。嵌套查询的意思是,一个查询语句块可以嵌套在另外一个查询块的where子句中,称为嵌套查询。其中外层查询也称为父查询,主查询。内层查询也称子查询,从查询。 嵌套查询的工作方式是:先处理内查询,由内向外处理,外层查询利用内层查询的结果嵌套查询不仅仅可以用于父查询select语句使用。还可以用于insert、update、delete语句或其他子查询中。
OECOM
2020/07/01
4.2K0
嵌套查询效率_sql嵌套查询例子
嵌套查询是 SQL 中表达能力很强的一种机制,既给应用带来了方便也给查询优化带来了很大的挑战。本文总结一下经典的单机系统对嵌套查询的优化。
全栈程序员站长
2022/09/27
2.4K0
sql server嵌套查询实验_exists嵌套查询
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/169426.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/22
1.8K0
sql的嵌套查询_嵌套查询和嵌套结果的区别
SQL连接查询和嵌套查询详解 连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询。连接查询是数据库中最最要的查询,
全栈程序员站长
2022/09/22
3.9K0
sql的嵌套查询_嵌套查询和嵌套结果的区别
mysql DATE_SUB() 函数
SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 5 DAY) AS SubtractDate FROM Orders
DencyCheng
2019/03/05
1.8K0
sql的嵌套查询_sql子查询嵌套优化
最近在做各类小应用,用到了MYSQL,有时候会用到一些比较复杂的嵌套查询,在研究怎么通过SQL实现这些。 假设下面这张表(stu)描述学生的基本信息:
全栈程序员站长
2022/09/22
5.2K0
sql嵌套查询和连接查询_sql子查询嵌套规则
WHERE department_id=( SELECT department_id
全栈程序员站长
2022/11/07
4K0
sql数据库嵌套查询_select嵌套查询
where 学号 = (select 学号 from 学生 where 姓名=”xx”);
全栈程序员站长
2022/09/22
3.8K0
sql嵌套查询例子_sql的多表数据嵌套查询
查询学生上课人数超过 “Eastern Heretic” 的任意一门课的学生人数的课程信息,请使用 ANY 操作符实现多行子查询。(Lintcode刷题记录)
全栈程序员站长
2022/09/22
3.1K0
SQL嵌套查询_sql嵌套查询返回多个字段
说到嵌套查询,首先得理解嵌套查询是什么意思,简单来说就是,一个查询语句可以嵌套在另外一个查询语句的where子句中。外层的查询称为父查询(主查询),内层的查询称为子查询(从查询)。
全栈程序员站长
2022/09/22
2.9K0
SQL嵌套查询_sql差集嵌套
派生表就是一个由查询结果生成的临时表。他是在外部查询的 FROM 中定义的。派生表的存在范围只是在外部查询中,只要外部查询结束了,派生表也就不存在了。派生表一定要写在 FROM 后面范围内,用()括起来。后面跟着派生表的名称。
全栈程序员站长
2022/09/22
2.2K0
SQL嵌套查询_sql差集嵌套
sql嵌套查询效率_sql嵌套查询返回多个字段
为了查询一个字段,使用了五层嵌套循环,但是花费了约1分钟 但是5个表的数据每个最多只有10条,怎么会这么慢呢?
全栈程序员站长
2022/09/22
2.8K0
sql嵌套查询效率_sql嵌套查询返回多个字段
Gorm-嵌套查询
嵌套查询是一种在一个查询语句中嵌套另一个查询语句的方式。在Gorm中,可以使用Preload方法来实现嵌套查询。
堕落飞鸟
2023/04/24
8950
sql中的嵌套查询_sql的多表数据嵌套查询
测试的时候发现取出的是一条数据, 因为测试的时候是一天中的两条数据, 没有不同的日期,所以当日以为是正确的 ,然而第二天写入数据了,要取出数据,却发现没有数据, 返回空的行, 以为都是代码又有问题 了,找了半天都没有 ,仔细看看了存储过程中的代码,发现这样返回的数据的确是空的。
全栈程序员站长
2022/09/22
7.1K0
实验3.4 嵌套查询
掌握SELECT语句的嵌套使用,实现多表的复杂查询,进一步理解SELECT语句的高级使用方法。
week
2018/08/27
8770
SELECT 语句中的 子查询(Sub Query)
子查询(Sub Query)或者说内查询(Inner Query),也可以称作嵌套查询(Nested Query),是一种嵌套在其他 SQL 查询的 WHERE 子句中的查询。
一个会写诗的程序员
2018/08/17
3.2K0

相似问题

MySQL SELECT IN with sub查询

21

Mysql使用update和sub查询

11

MYSQL insert after sub查询with count

30

DATE_SUB命名查询MYSQL

10

MYSQL查询Slow - Sub查询和临时表

21
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档