Android Jetpack Compose學習筆記

MVI架構

在Jetpack Compose官方介紹視頻里残腌,設計團隊提到Compose是基于MVI架構設計的,基礎架構演變從MVC、MVP净响、MVVM都是圍繞著View和Model關系來展開的,MVI也不例外白翻,如何“高內聚乍炉,低耦合”地進行程序設計是程序員永恒的命題。

我理解的MVI可以看做是“函數式編程思想”的一種表達形式滤馍,這和RX有點類似岛琼,整個View和Model的關系是以一種流式或者說響應式的方式進行組織的(也有點像大學里學習的《信號與系統》課程中對于信號的處理過程:input -> filter -> output),用戶輸入或者其他數據源的變更產生了一個Intent意圖(這是概念上的意圖巢株,和Android的Intent類沒什么關系)槐瑞,Model根據意圖輸出State狀態(tài),View根據State進行渲染阁苞。與傳統每個系統維護各自的狀態(tài)不同的是困檩,每一刻View的呈現都是根據Model的狀態(tài)來驅動的,即每次發(fā)生狀態(tài)的變化那槽,都擦掉整個畫布悼沿,重新根據Model產生的狀態(tài)進行渲染,這樣就去掉了View內部的狀態(tài)骚灸,保證View的渲染肯定對Model最準確的表達糟趾,Model到View的過程是函數式的,即無狀態(tài)的,View可以看做是一個filter义郑,固定的input就有固定的output蝶柿。ReactiveX其實最初的設計理念應該就是想將對事件的處理變成這樣一種無狀態(tài)的流式過程吧,雖然實際項目中更多的是將RX當做一種異步調度框架進行使用非驮。

MVI架構

這種每一次都擦除整個畫布的方式又和游戲開發(fā)中渲染過程很像交汤,整個世界是一個mainLoop,所有的變化都是通過每一次的update來完成的院尔,當我們決定怎么渲染這個世界后蜻展,渲染引擎就開始以流水線的方式運行,渲染管線Pipline經歷Vertex邀摆,Mesh纵顾, Rasterization等等階段,將邏輯數據經過點栋盹、線施逾、面、紋理例获、光照汉额、裁剪、柵格化等等流水線上每一個環(huán)節(jié)進行的處理最終形成了一張二維的畫面榨汤,給到屏幕去顯示蠕搜,每一幀都在重新畫一幅畫。

這種方式當也能更加直觀地以Declarative聲明式的方式進行編碼收壕,但每一次都重新繪制整個畫布的方式妓灌,在高效的GPU渲染管線上還好說(雖然也會用很多騷操作去優(yōu)化處理流程),放到CPU的邏輯計算階段代價就太大了吧蜜宪,我只是想更新一個文案虫埂,難道要整個布局重新繪制一次?所以一般采用這種方式進行設計的系統都需要在重繪的范圍上進行把控圃验,Jetpack Compose所謂的Recomposition重組的概念大概就是這么個事情吧掉伏,如何準確的識別狀態(tài)的變化,將重繪控制在最小的范圍內澳窑,就是整個Compose引擎的目的所在斧散。

Composable函數

@Composable
fun Greeting(name: String) {
    Text(text = "Hello $name!")
}

Jetpack Compose的Hello World是以這樣一個Greeting開始的,關于Composable函數的幾點值得注意:

  • @Composable注解和suspend關鍵字一樣是對函數類型的一個聲明照捡。
  • Composable函數必須運行在Compose環(huán)境中颅湘。
  • Composable函數是函數式的,即不產生返回值栗精,沒有Side Effect副作用闯参。
  • Composable函數通過調用其他Composable函數以組合的方式進行工作瞻鹏,如上面這個函數中的Text也是一個Composable函數,會在頁面中渲染一個文本框鹿寨。

引用官方在Compose編程思想中所提到的對Composable函數的描述:

  • 可組合函數可以按任何順序執(zhí)行新博。
  • 可組合函數可以并行執(zhí)行。
  • 重組會跳過盡可能多的可組合函數和 lambda脚草。
  • 重組是樂觀的操作赫悄,可能會被取消。
  • 可組合函數可能會像動畫的每一幀一樣非常頻繁地運行馏慨。

總結來講埂淮,Composable函數盡量去按照函數式編程的規(guī)范不產生side effect地去編寫,實際使用經驗還得通過項目實踐去感受呀写隶,期待Compose能早日實裝~

(以上是對Jetpack Compose不斷學習探索過程中的所想倔撞,只是我個人的一個筆記,持續(xù)學習記錄中慕趴,歡迎指正~)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末痪蝇,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子冕房,更是在濱河造成了極大的恐慌躏啰,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耙册,死亡現場離奇詭異给僵,居然都是意外死亡,警方通過查閱死者的電腦和手機详拙,發(fā)現死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門想际,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人溪厘,你說我怎么就攤上這事∨票” “怎么了畸悬?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長珊佣。 經常有香客問我蹋宦,道長,這世上最難降的妖魔是什么咒锻? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任冷冗,我火速辦了婚禮,結果婚禮上惑艇,老公的妹妹穿的比我還像新娘蒿辙。我一直安慰自己拇泛,他們只是感情好,可當我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布思灌。 她就那樣靜靜地躺著俺叭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪泰偿。 梳的紋絲不亂的頭發(fā)上熄守,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機與錄音耗跛,去河邊找鬼裕照。 笑死,一個胖子當著我的面吹牛调塌,可吹牛的內容都是我干的晋南。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼烟阐,長吁一口氣:“原來是場噩夢啊……” “哼搬俊!你這毒婦竟也來了?” 一聲冷哼從身側響起蜒茄,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤唉擂,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后檀葛,有當地人在樹林里發(fā)現了一具尸體玩祟,經...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年屿聋,在試婚紗的時候發(fā)現自己被綠了空扎。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡润讥,死狀恐怖转锈,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情楚殿,我是刑警寧澤撮慨,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站脆粥,受9級特大地震影響砌溺,放射性物質發(fā)生泄漏。R本人自食惡果不足惜变隔,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一规伐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧匣缘,春花似錦猖闪、人聲如沸鲜棠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽岔留。三九已至,卻和暖如春检柬,著一層夾襖步出監(jiān)牢的瞬間献联,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工何址, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留里逆,地道東北人。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓用爪,卻偏偏與公主長得像原押,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子偎血,可洞房花燭夜當晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內容