kotlin中数据类重写setter getter的正确方法

时间:2021-11-09 23:32:42

概述

在开发过程中,经常会创建一些数据里,其没有任何逻辑功能,仅仅来用来保存数据。在Kolin中,将这些类统一称为数据类,用关键字data标记。

?
1
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方法,也给大家造成了一定的麻烦。

举个例子:

?
1
data class OrderBean(val createTime: Long)

后端返回的订单数据中,createTime这个字段是长整型的时间戳,但是前端需要转成yyyy-MM-dd这种格式,或者yyyy年MM月dd日这种,再或者更加友好一点,根据时间段,转成1小时前、2天前、一周前这种,在实际开发中都是常有的情况,在Java中我们可以很方便的在getter方法中做这些处理,但是kotlin的getter方法都是内部封装的,并不直接支持重写,我看到网上有些答案是像这样处理的:

?
1
2
3
4
data class OrderBean(val _createTime: Long){
 val createTime:String
 get() = { ...do something }
}

这样处理其实并没有真正改变createTime的值,反而会造成一些更大的麻烦,比如,数据类中自动生成的equals(),toString()等一些方法还是会沿用长整型的值,而且当你做某些值对比的时候,会产生一些不可预测的结果。

正确的姿势

有以下三种,你可以根据自己的业务逻辑和团队的话语权进行选择:

  • 让后端改:如果有可能的话,这是最合理,最恰当的方式,后端直接返回我们需要的字段形式,节省了移动端,web端,小程序端等每端各写一套逻辑的时间,并且万一哪段比较坑,实现出来的时间跟你们不一样,可能你们每个都要复查一遍。另外,后端写的话,一旦需求变更,后端处理起来要更加简单方便。
  • 不用data class,使用常规的class:不要拘泥于建议,谁说这些数据实体类就必须要用data class的,使用IDE去自动生成,照样可以,而且还实现了自己的完全控制。
  • 另外创建一个安全的变量:如果在团队中实在人微言轻,有非要用data class,那就去另外创建一个变量,比如:
?
1
2
3
4
data class OrderBean(val createTime: Long){
 val createTimeShow:String
  get() = { ...do something }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:https://www.jianshu.com/p/aec461fae90e