码迷,mamicode.com
首页 > 其他好文 > 详细

Kotlin 一个好用的新功能:Parcelize

时间:2017-12-15 15:08:03      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:dex   适用于   查看   公众   场景   优点   div   高级   2.3   

技术分享图片

在开发中,如果有需要用到序列化和反序列化的操作,就会用到 Serializable 或者 Parcelable,它们各有优缺点,会适用于不同的场景。

Serializable 的优点是实现简单,你只需要实现一个 Serializable 接口,并不需要任何额外的代码,但是它的序列化和反序列化,实际上是使用反射做的,所以效率会略低,并且它会在序列化的过程中,会创建很多临时变量,所以更容易触发 GC。

Parcelable 需要开发者自己去实现序列化的规则,所以会增加代码量,正是因为规则确定,所以效率会提高很多,并且不容易触发 GC。

在 Android 下,通常我会推荐使用 Parcelable ,但是它需要实现太多模板代码了。那么,有没有办法让它和 Serializable 一样,只经过简单的配置就达到我们序列化的需求呢?那就看看 Kotlin 新支持的 Parcelize 了。

一、Kotlin 的 Parcelize

Parcelize 是 Kotlin 在 1.1.4 中,新增加的功能。

如果你需要使用它,先要保证 Android Studio 对 Kotlin 的插件已经升级到 1.1.4 之上的版本,现在的最新版是 1.2.10 ,我这里刚升级了。

技术分享图片

在新版的 Kotlin 插件中,已经自动包含了一个自动 Parcelable 实现生成器。简单来说,只需要再主函数中,声明序列化的属性并添加一个 @Parcelize 注解,它将自动为我们创建 writeToParcel()createFromParcel()。也就是对开发者而言,只需要加一个 @Parcelize 注解,其他的和正常的类没有区别。

二、使用 Parcelize

2.1 常规使用 Parcelable

在 Kotlin 没有支持 @Parcelize 的时候,我们使用 Parcelable 的话,写的 Model 类,大概是这样的。

技术分享图片

2.2 使用 @Parcelize

而如果使用了 @Parcelize 的话,这些模板代码都是会帮我们自动生成,我们只需要增加一个 @Parcelize 注解就好了。

技术分享图片

有没有感觉到代码量的减少?

2.3 实际上生成的代码

这两个类,编译完以后,实际上是一致的。我们这边反编译之后,看看 UserParcelize() 的代码。

技术分享图片

@Parcelize 注解实际上就是帮我们自动生成了 writeToParcel()createFromParcel(),其实并没有什么高深的地方,但是这一点可以节约我们的代码量。

三、前期配置

@Parcelize 使用起来确实非常的方便,但是在此之前,我们还要进行一些简单的配置。

3.1 Kotlin 版本

前面提到,@Parcelize 是需要 Kotlin 1.1.4 之上的版本才支持,所以你需要保证你的 Kotlin 版本为最新的就好了。升级 Kotlin 如前文所述,直接升级 Kotlin 插件即可。升级完成之后,你可以在 Preferences 中,通过 Kotlin Compiler 查看当前支持的版本,我这里使用的是 1.2 版本。

技术分享图片

3.2 Gradle 配置

@Parcelize 是一个实验室功能,所以还需要在 Gradle 中,增加 experimental 配置。

技术分享图片

3.3 解决 Lint 错误

直接使用 @Parcelize 你将面临一个 Lint 的错误提示。当然 AS 已经为我们做出了解决它的提示。

技术分享图片

只需要增加 @SuppressLint("ParcelCreator") 就可以忽略它就可以了。

今天的 Kotlin 小技巧,对你有没有帮助?有什么想法可以在留言区讨论。

今天在承香墨影公众号的后台,回复『成长』。我会送你一些我整理的学习资料,包含:Android反编译、算法、设计模式、虚拟机、Linux、Kotlin、Python、爬虫、Web项目源码。

推荐阅读:

技术分享图片

Kotlin 一个好用的新功能:Parcelize

标签:dex   适用于   查看   公众   场景   优点   div   高级   2.3   

原文地址:http://www.cnblogs.com/plokmju/p/8042707.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!