您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。