博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Activity之间传递数据的方式及常见问题总结
阅读量:6695 次
发布时间:2019-06-25

本文共 2331 字,大约阅读时间需要 7 分钟。

转载: 

Activity之间传递数据一般通过以下几种方式实现:
1. 通过intent传递数据
2. 通过Application
3. 使用单例
4. 静态成员变量。(可以考虑 
WeakReferences
5. 持久化(sqlite、share preference、file等)
 
一、通过intent传递数据
(1)直接传递,intent.putExtra(key, value)
(2)通过bundle,intent.putExtras(bundle);
TL:
(1)这两种都要求传递的对象必须可序列化( able、Serializable)
(2)Parcelable实现相对复杂
(3)关于Parcelable和Serializable,官方说法:
        
Serializable: it's error prone and horribly slow. So in general: stay away from 
Serializable if possible.
     也就是说和Parcelable相比,Seriaizable容易出错并且速度相当慢。是否这样,可参见 说明。

(4)通过intent传递数据是有大小限制滴,超过限制,要么抛异常,要么新的Activity启动失败,所以还是很严重的啊,可参见说明。

 
二、Application
   这个应该也都接触过,将数据保存早全局Application中,随整个应用的存在而存在,这样很多地方都能访问。具体使用就不多说了。
但是需要
注意的是:
  当由于某些原因(比如系统内存不足),我们的app会被系统强制杀死,此时再次点击进入应用时,系统会直接进入被杀死前的那个界面,制造一种从来没有被杀死的假象。那么问题来了,系统强制停止了应用,进程死了,那么再次启动时Application自然新的,那里边的数据自然木有啦,如果直接使用很可能报空指针或者其他错误。
  因此还是要考虑好这种情况的:
  (1)使用时一定要做好非空判断
  (2)如果数据为空,可以考虑逻辑上让应用直接返回到最初的activity,比如用 
FLAG_ACTIVITY_CLEAR_TASK 或者 
BroadcastReceiver 杀掉其他的activity。
 
三、使用单例
比如一种常见的写法:
public class DataHolder {  private String data;  public String getData() {return data;}  public void setData(String data) {this.data = data;}  private static final DataHolder holder = new DataHolder();  public static DataHolder getInstance() {return holder;}}
这样在启动activity之前:
DataHolder.getInstance().setData(data);
新的activity中获取数据:
String data = DataHolder.getInstance().getData();
四、静态Statis
这个可以直接在activity中也可以单独一个数据结构体,就和单例差不多了。
比如:
public class DataHolder {  private static String data;  public static String getData() {return data;}  public static String setData(String data) {this.data = data;}}
启动之前设置数据,新的activity获取数据。
 
注意:这些情况如果数据很大很多,比如bitmap,处理不当是很容易导致内存泄露或者内存溢出的。
所以可以考虑使用WeakReferences 将数据包装起来。
比如:
public class DataHolder {  Map
> data = new HashMap
>(); void save(String id, Object object) { data.put(id, new WeakReference
(object)); } Object retrieve(String id) { WeakReference objectWeakReference = data.get(id); return objectWeakReference.get(); }}
启动之前:
DataHolder.getInstance().save(someId, someObject);
新activity中:
DataHolder.getInstance().retrieve(someId);
这里可能需要通过intent传递id,如果数据唯一,id都可以不传递的。save() retrieve()中id都固定即可。
 
五、持久化数据
那就是sqlite、share preference、file等了。
优点:
(1)应用中所有地方都可以访问
(2)即使应用被强杀也不是问题了
缺点:
(1)操作麻烦
(2)效率低下
(3)io读写嘛,其实还是比较容易出错的

转载于:https://www.cnblogs.com/Jackie-zhang/p/10654715.html

你可能感兴趣的文章
Hibernate的fetch
查看>>
C#多线程案例基础
查看>>
WPF中的动画——(一)基本概念
查看>>
SQL Server 固定角色
查看>>
c# Ftp下载程序源代码解析
查看>>
利用NPOI开源的读写Excel、WORD等微软OLE2组件读写execl,控制样式或单元格
查看>>
走出浮躁的泥沼:浮躁的社会原因 控制好自己的物欲
查看>>
〖Linux〗Kubuntu设置打开应用时就只在打开时的工作区显示
查看>>
mysql导入sql文件过大或连接超时的解决办法
查看>>
Find Minimum in Rotated Sorted Array
查看>>
【linux】学习6
查看>>
用UltraISO制作的u盘ubuntu11.04,启动失败解决方案
查看>>
<audio> 标签简介
查看>>
Atitit.web预览播放视频的总结
查看>>
自动布局
查看>>
【转】功能测试的经验总结
查看>>
【转】每天一个linux命令(39):grep 命令
查看>>
【百度地图API】如何制作班级地理通讯录?LBS通讯录
查看>>
c# event Action 判断事件列表中是否存在这个委托
查看>>
Oracle初始化参数之memory_target
查看>>