android面试の通过Intent传递一些二进制数据的方法有哪些
1). 使用Serializable接口实现序列化。利用Bundle.putSerializable(Key,Object);这里的object对象需要实现serializable接口。
2). 实现Parcelable接口串行化。利用Bundle.putParcelable(Key, Object);这里Object对象需要实现Parcelable接口。
Android序列化对象主要有哪两种方法?
实现Serializable接口或者实现Parcelable接口。
android序列化实现Serializable接口跟实现Parcelable接口区别?
实现Serializable接口是 Java SE本身就支持的,而Parcelable是Android特有的功能,效率比实现Serializable接口高。实现 Serializable接口非常简单,声明一下就可以了,而实现Parcelable接口稍微复杂一些,但效率更高,推荐用这种方法提高性能。
序列化原因:
1.永久性保存对象,保存对象的字节序列到本地文件中;
2.通过序列化对象在网络中传递对象;
3.通过序列化在进程间传递对象。
2. 顺便延伸学习一下。
1)通过实现Parcelable接口序列化对象的步骤:
1、声明实现接口Parcelable
2、实现Parcelable的方法writeToParcel,将对象序列化为一个Parcel对象
3、实例化静态内部对象CREATOR实现接口Parcelable.Creator:
public static final Parcelable.Creator<T> CREATOR
其中public static final一个都不能少,内部对象CREATOR的名称也不能改变,必须全部大写。
4、完成CREATOR的代码,实现方法createFromParcel,将Parcel对象反序列化为你的对象
简而言之:通过writeToParcel将你的对象映射成Parcel对象,再通过createFromParcel将Parcel对象映射成你的对 象。也可以将Parcel看成是一个流,通过writeToParcel把对象写到流里面,在通过createFromParcel从流里读取对象,只不 过这个过程需要你来实现,因此写的顺序和读的顺序必须一致。
Parcel对象可以通过以下方法写入或读取byte, double, float, int, long, String这6种类型变量。
writeByte( byte ), readByte()
writeDouble(double ), readDouble()
writeFloat(float ), readFloat()
writeInt(int ), readInt()
writeLong(long ), readLong()
writeString(String), readString()
也可以读取或写入他们的数组
writeBooleanArray( boolean []), readBooleanArray( boolean []), createBooleanArray()
writeByteArray(byte []), writeByteArray( byte [], int , int ), readByteArray( byte []), createByteArray()
writeCharArray(char []), readCharArray( char []), createCharArray()
writeDoubleArray(double []), readDoubleArray( double []), createDoubleArray()
writeFloatArray(float []), readFloatArray( float []), createFloatArray()
writeIntArray(int []), readIntArray( int []), createIntArray()
writeLongArray(long []), readLongArray( long []), createLongArray()
writeStringArray(String[]), readStringArray(String[]), createStringArray()
writeSparseBooleanArray(SparseBooleanArray), readSparseBooleanArray()
示例代码
import java.util.Date;
import android.os.Parcel;
import android.os.Parcelable;
public class ParcelableDate implements Parcelable { //声明实现接口Parcelable
//这里定义了两个变量来说明读和写的顺序要一致
public long mId;
public Date mDate;
public ParcelableDate( long id, long time) {
mId = id;
mDate = new Date(time);
}
public ParcelableDate(Parcel source) {
//先读取mId,再读取mDate
mId = source.readLong();
mDate = new Date(source.readLong());
}
@Override
public int describeContents() {
return 0 ;
}
//实现Parcelable的方法writeToParcel,将ParcelableDate序列化为一个Parcel对象
@Override
public void writeToParcel(Parcel dest, int flags) {
//先写入mId,再写入mDate
dest.writeLong(mId);
dest.writeLong(mDate.getTime());
}
//实例化静态内部对象CREATOR实现接口Parcelable.Creator
public static final Parcelable.Creator<ParcelableDate> CREATOR = new Creator<ParcelableDate>() {
@Override
public ParcelableDate[] newArray( int size) {
return new ParcelableDate[size];
}
//将Parcel对象反序列化为ParcelableDate
@Override
public ParcelableDate createFromParcel(Parcel source) {
return new ParcelableDate(source);
}
};
}