热门标签 | 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) {}}}



推荐阅读
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 本文介绍了在处理不规则数据时如何使用Python自动提取文本中的时间日期,包括使用dateutil.parser模块统一日期字符串格式和使用datefinder模块提取日期。同时,还介绍了一段使用正则表达式的代码,可以支持中文日期和一些特殊的时间识别,例如'2012年12月12日'、'3小时前'、'在2012/12/13哈哈'等。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文介绍了GregorianCalendar类的基本信息,包括它是Calendar的子类,提供了世界上大多数国家使用的标准日历系统。默认情况下,它对应格里高利日历创立时的日期,但可以通过调用setGregorianChange()方法来更改起始日期。同时,文中还提到了GregorianCalendar类为每个日历字段使用的默认值。 ... [详细]
  • ***byte(字节)根据长度转成kb(千字节)和mb(兆字节)**parambytes*return*publicstaticStringbytes2kb(longbytes){ ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • 本文介绍了为什么要使用多进程处理TCP服务端,多进程的好处包括可靠性高和处理大量数据时速度快。然而,多进程不能共享进程空间,因此有一些变量不能共享。文章还提供了使用多进程实现TCP服务端的代码,并对代码进行了详细注释。 ... [详细]
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社区 版权所有