iOS 代碼的 taste(品味)

最近看了不少代碼,想起寫代碼有意思的地方之一在于,實現(xiàn)同一個 feature,修復(fù)同一個 bug,不同程序員可以寫出風(fēng)格迥異的代碼,甚至流程也不同,雖然最后都可行,從結(jié)果論的角度對用戶來說是一致的。我們可以稱這種差異為個人 taste,taste 有好壞高低之分,但有時候如何評定卻很難有一個清晰準確的界定標準,一般來說代碼是越簡單越清晰越容易測試越好,但簡單清晰容易測試又是另一個維度的標準,又會產(chǎn)生分歧,真要較真起來可以無窮無盡越扯越遠。

我有個小例子,大家可以按自己的經(jīng)驗來分個優(yōu)劣。

UserSession

只要涉及用戶登錄的 App,都少不了有個 UserSession 的類,記錄和用戶相關(guān)的一切數(shù)據(jù)和行為,并在用戶登出的時候做銷毀。UserSession 是一個一旦創(chuàng)建之后,大部分的業(yè)務(wù)模塊都需要訪問的實例對象,其他 class 如何訪問 UserSession,或者說 UserSession 如何傳遞到各個 class,這里面的做法就多了。

問題:ControllerA,ControllerB,ControllerC 都需要訪問 UserSession 實例,如何傳遞?

方式一:構(gòu)造傳遞

所有的 Controller 在 init 方法里都傳入 UserSession,之后再內(nèi)部持有一個 strong property,類結(jié)構(gòu)如下圖:

tasteSessionA.png

如果使用這種方式,所有需要引用 UserSession 的地方都需要以 init 的方式傳入,包括 Controller 內(nèi)部的 View、Presenter 等對象,View 可能還有子 View,層層疊疊以樹形結(jié)構(gòu),UserSession 將出現(xiàn)在每一個相關(guān) Class 的 init 方法之內(nèi)。

方式二:方法參數(shù)傳遞

Controller 本身并不持有 UserSession 的實例,每個需要用到 UserSession 的方法以參數(shù)傳入,如下圖:

tasteSessionB.png

這種方式相較方式一,UserSession 作為每個方法的參數(shù)將出現(xiàn)在更多的地方。顯然,不持有 strong property 有他的好處,比如不會出現(xiàn) Controller 無法釋放導(dǎo)致 UserSession 也無法銷毀的情況。UserSession 和 Controller 之間的依賴關(guān)系也更清楚,看 .h 中的方法就一目了然。另外需要測試某個方法的時候,要比較容易,方法的聲明里就有完整的 context。

方式三:內(nèi)部直接持有

Controller 在 .m 文件內(nèi)部通過另一個 UserMgr 實例來統(tǒng)一獲取 UserSession,如下圖:

tasteSessionC.png

這種方式在 .h 中看不出 Controller 和 UserSession 的關(guān)系,在 .m 中通過另一個類(xxxMgr、xxxFactory、xxxService)來獲取 UserSession 實例。好處是 .h 文件干凈一些,但 .m 中可能各處都有獲取 UserSession 的代碼,一旦代碼量多了之后很難理清 Controller 和 UserSession 二者之間的依賴關(guān)系。

以上三種方式我都見到過,不同方式對代碼的影響也不同,這是個典型的例子,一個完整 App 里往往有多個類似 UserSession 需要被多處引用的對象,三種方式最后都不會影響功能的正常實現(xiàn),但在代碼閱讀維護上存在一些差異。

歡迎大家留言,說說自己項目里的方式,以及支持的理由,秀下自己的 taste。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,694評論 19 139
  • iOS網(wǎng)絡(luò)架構(gòu)討論梳理整理中。。。 其實如果沒有APIManager這一層是沒法使用delegate的,畢竟多個單...
    yhtang閱讀 5,494評論 1 23
  • *面試心聲:其實這些題本人都沒怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個offer,總結(jié)起來就是把...
    Dove_iOS閱讀 27,655評論 30 472
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,834評論 18 399
  • 每個深夜的靈魂都是孤獨又脆弱的??斩吹囊箍梢约姆懦了?,不安,失落,興奮各種情緒,它會用深邃包容著一切。 第一個火車...
    晚安世界閱讀 630評論 0 2

友情鏈接更多精彩內(nèi)容