android开发没什么神秘的地方,只不过是又一个新的操作系统而已(而且还是基于Linu的)。下面记录下最近的开发心得。
android整个上层java开发框架可以分为四个方面:界面(activity和appwidget)、消息(Intent和Message)、服务(Service)和数据(Sqllite、Content Provider)。
开发要点摘记:
1、新的序列化方式:
android提供了一种新的类型:Parcel。本类被用作封装数据的容器,封装后的数据可以通过Intent或IPC传递。
除了基本类型以外,只有实现了Parcelable接口的类才能被放入Parcel中。
Parcelable实现要点:需要实现三个东西
1)writeToParcel 方法。该方法将类的数据写入外部提供的Parcel中.声明如下:
writeToParcel (Parcel dest, int flags) 具体参数含义见javadoc
2)describeContents方法。没搞懂有什么用,反正直接返回0也可以
3)静态的Parcelable.Creator接口,本接口有两个方法:
createFromParcel(Parcel in) 实现从in中创建出类的实例的功能
newArray(int size) 创建一个类型为T,长度为size的数组,仅一句话(return new T[size])即可。估计本方法是供外部类反序列化本类数组使用。
示例:
需求:我们经常需要在多个部件(activity或service)之间通过Intent传递一些数据,简单类型(如数字、字符串)的可以直接放入Intent。复杂类型(例如,J2ee中的Bean)的必须实现Parcelable接口。示例如下:
class SampleBean implements Parcelable
{
private Bundle mBundle=new Bundle();
public String getArriveTime()
{
return mBundle.getString("arriveTime");
}
public String getOlTime()
{
return mBundle.getString("olTime");
}
public void setArriveTime(String arriveTime)
{
this.mBundle.putString("arriveTime", arriveTime);
}
public void setOlTime(String olTime)
{
this.mBundle.putString("olTime", olTime);
}
public int describeContents()
{
// TODO Auto-generated method stub
return 0;
}
public void writeToParcel(Parcel out, int arg1)
{
// TODO Auto-generated method stub
out.writeBundle(this.mBundle);
}
public static final Parcelable.Creator CREATOR = new Parcelable.Creator() {
public TrainInfo createFromParcel(Parcel in)
{
SampleBean ti=new SampleBean();
ti.mBundle=in.readBundle();
return ti;
}
public SampleBean[] newArray(int size)
{
return new SampleBean[size];
}
};
}
这里采用Bundle是因为在Parcel中并没有key的概念存在,而Bundle相当于Map。
以下转:http://hi.baidu.com/anly_jun/blog/item/8ccbb8ad223afd024a36d645.html/cmtid/a6a8d0ee295374f6b2fb95ef
android 中Parcel 的使用,他是一个存储基本数据类型和引用数据类型的容器,在andorid 中通过IBinder来绑定数据在进程间传递数据。 Parcel parcel = Parcel.obtain();// 获取一个Parcel 对象 下面就可以对其进行方法进行操作了,createXXX(),wirteXXX(),readXXX(), 其中dataPosition(),返回当前Parcel 当前对象存储数据的偏移量,而setDataPosition(),设置当前Parcel 对象的偏移量,方便读取parcel 中的数据,可问题就出在我读取出来的数据要么是空(null),要么永远是第一个偏移量处的值,存储和读取数据的。Parcel采用什么机制实现的,是以什么形式的存储的,然后我才能任意对其操作,读取目标数据。 基本数据类型的取值范围, boolean 1bit short 16bit int 32bit long 64bit float 32bit double 64bit char 16bit byte 8bit 由此我可以猜想,Parcel 32bit 作为基本单位存储写入的变量,4byte*8=32bit,在内存中的引用地址变量是采用16进制进行编码,且作为偏移量,即偏移量是4的倍数,0,4,8,12,16,20,24,28,32,36,40,44,48......4*N, f(x) = 4*y{y>=0&y是自然数} 我想绝对不会出现向偏移量是3,6,9这样的数据。。。 由此我们可以推断出,无论他存储的是基本数据类型或引用数据类型的变量,都是以32bit基本单位作为偏移量, parcel.writeInt(1); parcel.writeInt(2); parcel.writeInt(3); parcel.writeInt(4); parcel.writeInt(5); parcel.writeInt(6); parcel.writeInt(7); parcel.writeInt(81011111); parcel.writeFloat(1f); parcel.writeFloat(1000000000000000000000000000000000000f); parcel.writeXXX(),每写一次数据,在32bit的空间里能够存储要放入的变量,怎只占一个偏移量,也就之一动4个位置,而当存储的数据如 parcel.writeFloat(1000000000000000000000000000000000000f);他就自动往后移动, parcel.writeString("a"); parcel.writeString("b"); parcel.writeString("d"); parcel.writeString("c"); 和 parcel.writeString("abcd"); 的区别。有此可见,他的内存的分配原来是这样的。 那我怎样才能把我存进去的书据依次的去出来呢?setDataPosition(),设置parcel 的偏移量,在readXXX(),读取数据 int size = parcel.dataSize(); int i = 0; while (i <= size ) { parcel.setDataPosition(i); int curr_int = parcel.readInt(); i+=4; int j = 0; j++; } 由此可见parcel 写入数据是按照32bit 为基本的容器,依次存储写入的数据,基本和引用(其实引用的也是有多个基本数据类型组合而成OBJECTS-属性|方法),读取的时候我们就可以按照这种规律根据目标数据的偏移量的位置(curr_position),以及偏移量的大小(size),,取出已经存进去的数据了 int i = curr_position; while (i <= size ) { parcel.setDataPosition(i); int curr_int = parcel.readXXXt(); i+=4; int j = 0; j++; } 这样就ok 了 他的createXXX()方法现在没用,用了在说吧! 总结一句话,java 中 基本数据类型的取值范围,引用类型的数据,相当于c中的指针,以及各进制之间的相互转换和灵活的引用,以及定制自己想要的任意进制数据类型。 |