热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaAndroid基础知识梳理(2)序列化

一、Parcelable和Serializable对象的序列化是把Java对象转化为字节序列并存储至一个存储媒介(硬盘或者内存)的过程,反

一、ParcelableSerializable

对象的序列化是把Java对象转化为字节序列并存储至一个存储媒介(硬盘或者内存)的过程,反序列化则是把字节序列恢复为Java对象的过程,但它们仅处理Java变量而不处理方法。

序列化的原因:

  • 永久性保存对象,保存对象的字节序列到本地文件中。Serializable
  • 通过序列化对象在网络中传递对象。Serializable
  • 通过序列化在进程间传递对象。Parcelable

两种序列化的区别:

  • Serializable只需要对某个类以及它的属性实现Serializable接口即可,它的缺点是使用了反射,序列化的过程比较慢,这种机制会在序列化的时候创建许多的临时对象,容易引发频繁的gc
  • ParcelableAndroid平台特有的,在使用内存的时候性能更好,但Parcelable不能使用在要将数据存储在磁盘的情况下,因为Parcelable不能很好的保证数据的持续性在外界有变化的情况。

二、序列化在Android平台上的应用

2.1 通过intent传递复杂对象

intent支持传递的数据类型包括:

  • 基本类型的数据、及其数组。
  • String/CharSequence类型的数据、及其数组。
  • Parcelable/Serializable,及其数组/列表数据。

2.2 SharePreference存储复杂对象

三、SerializableParcelable

3.1 使用Serializable的读写操作

首先定义我们要序列化的对象。

public class SBook implements Serializable { public int id; public String name;
}

进行读写操作:

private void readSerializable() {ObjectInputStream object = null;try {FileInputStream out = new FileInputStream(Environment.getExternalStorageDirectory() + "/sbook.txt");object = new ObjectInputStream(out);SBook book = (SBook) object.readObject();if (book != null) {Log.d(TAG, "book, id=" + book.id + ",name=" + book.name);} else {Log.d(TAG, "book is null");}} catch (Exception e) {Log.d(TAG, "readSerializable:" + e);} finally {try {if (object != null) {object.close();}} catch (Exception e) {Log.d(TAG, "readSerializable:" + e);}}}private void writeSerializable() {SBook book = new SBook();book.id = 1;book.name = "SBook";ObjectOutputStream object = null;try {FileOutputStream out = new FileOutputStream(Environment.getExternalStorageDirectory() + "/sbook.txt");object = new ObjectOutputStream(out);object.writeObject(book);object.flush();} catch (Exception e) {Log.d(TAG, "writeSerializable:" + e);} finally {try {if (object != null) {object.close();}} catch (Exception e) {Log.d(TAG, "writeSerializable:" + e);}}}

3.2 使用Parcelable的读写操作

定义序列化对象:

public class PBook implements Parcelable {public int id;public String name;public PBook(int id, String name) {this.id = id;this.name = name;}private PBook(Parcel in) {id = in.readInt();name = in.readString();}public static final Parcelable.Creator CREATOR = new Parcelable.Creator() {@Overridepublic PBook[] newArray(int size) {return new PBook[size];}@Overridepublic PBook createFromParcel(Parcel source) {return new PBook(source);}};@Overridepublic int describeContents() {return 0;}@Overridepublic void writeToParcel(Parcel dest, int flags) {dest.writeInt(id);dest.writeString(name);}
}

写入和读取:

private Intent writeParcelable() {PBook tony &#61; new PBook(1, "tony");PBook king &#61; new PBook(2, "king");ArrayList list &#61; new ArrayList<>();list.add(tony);list.add(king);Intent intent &#61; new Intent();intent.putParcelableArrayListExtra("PBook", list);return intent;}private void readParcelable(Intent intent) {if (intent !&#61; null) {ArrayList list &#61; intent.getParcelableArrayListExtra("PBook");if (list !&#61; null) {for (PBook book : list) {Log.d(TAG, "readParcelable, id&#61;" &#43; book.id &#43; ", name&#61;" &#43; book.name);}}}}

四、SharePreference存储复杂对象

//obejct -> ObjectOutputStream(ByteArrayOutputStream) -> ByteArrayOutputStream() -> byte[] -> String -> spprivate void writeSP() {SBook book &#61; new SBook();book.id &#61; 2;book.name &#61; "sp";SharedPreferences sp &#61; getSharedPreferences("SBookSP", MODE_PRIVATE);ByteArrayOutputStream os &#61; new ByteArrayOutputStream();try {ObjectOutputStream object &#61; new ObjectOutputStream(os);object.writeObject(book);String base64 &#61; new String(Base64.encode(os.toByteArray(), Base64.DEFAULT));SharedPreferences.Editor editor &#61; sp.edit();editor.putString("SBook", base64);editor.apply();} catch (Exception e) {}}//sp -> string -> byte[] -> ByteArrayInputStream(byte[]) -> ObjectInputStream(ByteArrayInputStream) -> objectprivate void readSP() {SharedPreferences sp &#61; getSharedPreferences("SBookSP", MODE_PRIVATE);String sbook &#61; sp.getString("SBook", "");if (sbook.length() > 0) {byte[] base64 &#61; Base64.decode(sbook.getBytes(), Base64.DEFAULT);ByteArrayInputStream is &#61; new ByteArrayInputStream(base64);try {ObjectInputStream object &#61; new ObjectInputStream(is);SBook book &#61; (SBook) object.readObject();if (book !&#61; null) {Log.d(TAG, "readSP, id&#61;" &#43; book.id &#43; ", name&#61;" &#43; book.name);}} catch (Exception e) {}}}



推荐阅读
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
author-avatar
漂亮的花裙子
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有