您好,登录后才能下订单哦!
这篇文章将为大家详细讲解有关kotlin中数据类重写setter getter的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
概述
在开发过程中,经常会创建一些数据里,其没有任何逻辑功能,仅仅来用来保存数据。在Kolin中,将这些类统一称为数据类,用关键字data标记。
data class User(val name: String, val age: Int)
编译器会根据主构造器中声明的全部属性, 自动推断产生以下成员函数:
equals()/hashCode()函数对,
toString() 函数, 输出格式为 “User(name=John, age=42)” ,
componentN() 函数群, 这些函数与类的属性对应, 函数名中的数字 1 到 N, 与属性的声明顺序一致,
copy() 函数
如果在该数据类或者基类中重写了以上某个成员函数,将不会再自动推断,以重写的为准。
前言
kotlin的数据类,由于其内部封装了getter和setter方法,极大地简化了我们的编程代码,但同时其不能像java那样方便的重写getter或者setter方法,也给大家造成了一定的麻烦。
举个例子:
data class OrderBean(val createTime: Long)
后端返回的订单数据中,createTime这个字段是长整型的时间戳,但是前端需要转成yyyy-MM-dd这种格式,或者yyyy年MM月dd日这种,再或者更加友好一点,根据时间段,转成1小时前、2天前、一周前这种,在实际开发中都是常有的情况,在Java中我们可以很方便的在getter方法中做这些处理,但是kotlin的getter方法都是内部封装的,并不直接支持重写,我看到网上有些答案是像这样处理的:
data class OrderBean(val _createTime: Long){ val createTime:String get() = { ...do something } }
这样处理其实并没有真正改变createTime的值,反而会造成一些更大的麻烦,比如,数据类中自动生成的equals(),toString()等一些方法还是会沿用长整型的值,而且当你做某些值对比的时候,会产生一些不可预测的结果。
正确的姿势
有以下三种,你可以根据自己的业务逻辑和团队的话语权进行选择:
让后端改:如果有可能的话,这是最合理,最恰当的方式,后端直接返回我们需要的字段形式,节省了移动端,web端,小程序端等每端各写一套逻辑的时间,并且万一哪段比较坑,实现出来的时间跟你们不一样,可能你们每个都要复查一遍。另外,后端写的话,一旦需求变更,后端处理起来要更加简单方便。
不用data class,使用常规的class:不要拘泥于建议,谁说这些数据实体类就必须要用data class的,使用IDE去自动生成,照样可以,而且还实现了自己的完全控制。
另外创建一个安全的变量:如果在团队中实在人微言轻,有非要用data class,那就去另外创建一个变量,比如:
data class OrderBean(val createTime: Long){ val createTimeShow:String get() = { ...do something } }
关于“kotlin中数据类重写setter getter的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。