Android中数据序列化之Serializable与Parcelable

2023-12-04 13:32

本文主要是介绍Android中数据序列化之Serializable与Parcelable,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.Serializable

序列化Serializable是Java语言的特性之一,是将java对象转换成字节序列的过程,与之对应的是反序列化。反序列化是将字节序列转化为java对象的过程。  Serializable通过实现接口进行标志,只要定义的Java对象实现了Serializable接口,不有实现任何方法,java就会对该对象
诸如对如下类进行序列化及反序列化操作public class SerDemo implements Serializable {//开发工具提示生成的serialVersionUID private static final long serialVersionUID = 4046555564483893134L;private int age;//ArrayList已经实现了序列化接口private ArrayList<BannerImg> bannerImgs;public class BannerImg implements Serializable {private static final long serialVersionUID = -344227642091683711L;public String mIconUrl;public String mValue;public BannerImg(String mIconUrl, String mValue) {this.mIconUrl = mIconUrl;this.mValue = mValue;}}public SerDemo() {this.age = 0;this.bannerImgs = new ArrayList<>();}
}

对SerDemo进行序列化及反序列化操作示例:

//序列化需要把对象转换成诸如FileOutputSream等输出流,再转成ObjectOutputSteam,然后调用相应方法序列化保存到文件。private void writeToCache(SerDemo banner) {FileOutputStream fos = null;ObjectOutput objectOutput = null;//判断sd卡是否存在if (Environment.getExternalStorageState().equals(android.os.Environment.MEDIA_MOUNTED)) {//将指定WenkuBanner对象序列化到SD卡中try {//文件路径最好是灵活配置File file = new File(Environment.getExternalStorageDirectory() + "/ldm");fos = new FileOutputStream(file);objectOutput = new ObjectOutputStream(fos);if (objectOutput != null) {objectOutput.writeObject(banner);}} catch (Exception e) {e.printStackTrace();} finally {try {if (null != fos) {fos.close();}if (null != objectOutput) {objectOutput.close();}} catch (IOException e) {e.printStackTrace();}}} else {//提示SD卡不存在}}//模拟把一个Java对象反序列化//反序列化需要把文件数据转换成诸如FileInputSream等输入流,再转成ObjectInputSteam,然后调用相应方法转成对象。private SerDemo readFromCache() {File file = null;FileInputStream fis = null;ObjectInputStream ois = null;SerDemo banner = null;if (Environment.getExternalStorageState().equals(android.os.Environment.MEDIA_MOUNTED)) {//将指定WenkuBanner对象序列化到SD卡中try {//文件路径最好是灵活配置file = new File(Environment.getExternalStorageDirectory() + "/ldm");//这里还要判断文件是否存在fis = new FileInputStream(file);ois = new ObjectInputStream(fis);if (null != ois) {//获取到WenkuBanner对象banner = (SerDemo) ois.readObject();}} catch (Exception e) {e.printStackTrace();} finally {try {if (null != fis) {fis.close();}if (null != ois) {ois.close();}} catch (IOException e) {e.printStackTrace();}}} else {//提示SD卡不存在}return banner;}
  • Parcelable
    Parcelable是AndroidSDK提供的一种基于内存读写的高速序列化操作。在Android跨进程数据通讯中 数据对象一般要求实现Parcelable接口,实现Parcelable指定的方法。
    比如对下面类通过Parcelable进行序列化及反序列化

public class ParcelDemo implements Parcelable {private String name;private int age;private String subjcet;public ParcelDemo() {}//从Parcel中获取变量的内容protected ParcelDemo(Parcel in) {this.name = in.readString();this.age = in.readInt();this.subjcet = in.readString();}public static final Creator<ParcelDemo> CREATOR = new Creator<ParcelDemo>() {//反序列化方法,将writeToParcel方法写入的Parcel反序列成ParcelDemo@Overridepublic ParcelDemo createFromParcel(Parcel in) {return new ParcelDemo(in);}//这个方法是提供给其它类反序列化该类的数组时调用@Overridepublic ParcelDemo[] newArray(int size) {return new ParcelDemo[size];}};//接口内容描述 ,通常返回0即可@Overridepublic int describeContents() {return 0;}//实现序列化操作的方法,将类数据写到Parcel窗口中@Overridepublic void writeToParcel(Parcel parcel, int i) {parcel.writeString(name);parcel.writeInt(age);parcel.writeString(subjcet);}
}  开发工具实现Parcelable只会提示你要实现的方法,如果在AndroidStuiod中安装了Parcelable Code Generator插件,就会在提示生成方法时自动添加对应代码,非常方便。

这篇关于Android中数据序列化之Serializable与Parcelable的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/453640

相关文章

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

pandas数据的合并concat()和merge()方式

《pandas数据的合并concat()和merge()方式》Pandas中concat沿轴合并数据框(行或列),merge基于键连接(内/外/左/右),concat用于纵向或横向拼接,merge用于... 目录concat() 轴向连接合并(1) join='outer',axis=0(2)join='o

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速