Android_Intent

本文探讨了Android中Intent的数据大小限制及解决方案,包括使用EventBus、文件缓存、ContentProvider等。同时,对比了Serializable与Parcelable在不同场景下的适用性与优缺点。

一 Android中Intent传递数据的大小限制?如何解决该问题?

    大小限制大约是1MB:超过该限制可能导致 OOM。
    解决办法
        进程内:EventBus、文件缓存
        进程间:通过ContentProvider进行进程间数据共享和传递。

总结: 不要通过 Intent 在 Android 基础组件之间传递大数据(binder transaction 缓存为1MB)

 

二 Intent作用

Android中提供了Intent机制来协助应用间的交互与通讯,或者采用更准确的说法是,Intent不仅可用于应用程序之间,也可用于应用程序内部的activity, service和broadcast receiver之间的交互。Intent这个英语单词的本意是“目的、意向、意图”

 

三  Serializable Parcelable

android 中自定义的对象序列化的问题有两个选择一个是Parcelable,另外一个是Serializable。

1、永久性保存对象,保存对象的字节序列到本地文件中;

2、通过序列化对象在网络中传递对象;

3、通过序列化在进程间传递对象。 

  至于选取哪种可参考下面的原则:

1、在使用内存的时候,Parcelable类比Serializable性能高,所以推荐使用Parcelable类。

2、Serializable在序列化的时候会产生大量的临时变量,从而引起频繁的GC。

3、Parcelable不能使用在要将数据存储在磁盘上的情况,因为Parcelable不能很好的保证数据的持续性在外界有变化的情况下。尽管Serializable效率低点,也不提倡用,但在这种情况下,还是建议你用Serializable 。

实现: 

1、Serializable 的实现,只需要继承  implements Serializable 即可。这只是给对象打了一个标记,系统会自动将其序列化。

2、Parcelabel 的实现,需要在类中添加一个静态成员变量 CREATOR,这个变量需要继承 Parcelable.Creator接口。

 

Android 开发中,`Intent` 是组件之间通信的核心机制之一。它不仅用于启动 Activity、Service 或广播事件,还可以携带数据和标志(Flags)以控制组件的行为。关于 `WM_NEW_INTENT` 的问题,虽然这不是 Android SDK 中的标准消息标识符,但可以结合与 Intent 相关的消息处理机制进行探讨。 当一个已经存在的 Activity 被再次通过新的 Intent 启动时,如果该 Activity 的启动模式为 `singleTop`、`singleTask` 或 `singleInstance`,系统会调用其 `onNewIntent(Intent intent)` 方法,并将新的 Intent 传递进来。这一机制允许开发者在不创建新实例的情况下处理新的 Intent 数据[^1]。 例如,在 Activity 中重写 `onNewIntent` 方法的代码如下: ```java @Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); // 处理新的 Intent 数据 String action = intent.getAction(); if (Intent.ACTION_SEND.equals(action)) { String sharedText = intent.getStringExtra(Intent.EXTRA_TEXT); if (sharedText != null) { // 处理接收到的文本内容 } } } ``` 此外,自定义 Intent 的使用通常涉及定义特定的 Action 字符串,以便在应用内部或与其他应用交互时触发特定行为。例如,定义一个自定义 Intent Action 并发送广播的示例代码如下: ```java public static final String CUSTOM_ACTION = "com.example.myapp.CUSTOM_EVENT"; Intent customIntent = new Intent(CUSTOM_ACTION); customIntent.putExtra("data", "Custom Event Data"); sendBroadcast(customIntent); ``` 接收方可以通过注册 BroadcastReceiver 来监听这个自定义 Action,并执行相应的逻辑: ```java public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (intent.getAction().equals(CUSTOM_ACTION)) { String data = intent.getStringExtra("data"); // 执行自定义事件处理逻辑 } } } ``` 对于与 `WM_NEW_INTENT` 类似的底层消息处理机制,Android 系统内部确实存在一系列基于消息循环的通信方式,尤其是在处理 UI 消息和组件生命周期时。然而,这些通常是框架层的实现细节,开发者一般不需要直接操作它们。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值