一、传递Map对象
HashMap本身已经实现
Cloneable
、Serializable
(1)Cloneable 接口概念 :创建对象有两种方式: new 和 clone,当一个对象创建过程复杂,我们可以根据已有的对象直接来克隆一份,而不必关系创建的细节(原型模式)
(2)Java Object根类默认提供了clone方法:
protected native Object clone() throws CloneNotSupportedException;
一个本地方法,protected权限: 这样做是为避免我们创建每一个类都默认具有克隆能力
我们要使用一个对象的clone方法,必须Cloneable接口,这个接口没有任何实现,跟 Serializable一样是一种标志性接口
如果不实现Cloneable接口,会抛出CloneNotSupportedException异常
重写clone方法,使用public修饰(否则外部调用不到),调用父类的clone方法
例子:
public class CloneModel implements Cloneable{
private String name;
private int age;
@Override
public Object clone() throws CloneNotSupportedException {
return super.clone();
}
@Override
public String toString() {
return "CloneModel{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
实现传递HashMap对象
Map<String,String> params = new HashMap<>();
params.put("key","value");
Intent intent = new Intent(this, XXXXActivity.class);
intent.putExtra("parmas",(Serializable)params);
实现传递Bitmap
不要通过Intent直接传,无法生效,同时Intent可传递的数据大小有限(Intent传递是有大小限制的,具体在40KB左右)
- 本地资源只传递R.id,然后通过resource去解析出来
- 如果是SDCard中的文件,传递Uri
- 如果是网络流,先本地保存图片,然后再传递路径Uri
传递Bitmap总结
- 当大小为505以下的时候,正常传输
- 当大小为505-1024的时候,程序闪退,没有异常
- 当大小大于1024的时候,log会显示 !!! FAILED BINDER TRANSACTION !!!