資源描述:
《深入Android 【三】-組件入門》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫。
1、Android組件橫看成嶺側(cè)成峰,遠(yuǎn)近高低各不同。--《題西林壁》組件(Component),在談及所謂架構(gòu)和重用的時(shí)候,是一個(gè)重要的事情。很多時(shí)候都會(huì)說基于組件的軟件架構(gòu),指的是期望把程序做樂高似的,有一堆接口標(biāo)準(zhǔn)封裝完整的組件放在哪里,想用的時(shí)候取上幾個(gè)一搭配,整個(gè)程序就構(gòu)建完成了。在開篇的時(shí)候就在說,Android是一個(gè)為組件化而搭建的平臺(tái),它引入所謂Mash-Up的概念,這使得你在應(yīng)用的最上層,想做的不組件化都是很困難的一件事情(底層邏輯,好吧,管不了...)。具體說來,Android有四大組件四喜丸子:Activity、Service
2、、BroadcastReceiver、ContentProvider。Activity做一個(gè)完整的Android程序,不想用到Activity,真的是比較困難的一件事情,除非是想做綠葉想瘋了。因?yàn)锳ctivity是Android程序與用戶交互的窗口,在我看來,從這個(gè)層面的視角來看,Android的Activity特像網(wǎng)站的頁面。首先,一個(gè)網(wǎng)站,如果一張頁面都沒有,那...,真是一顆奇葩。而一張頁面往往都有個(gè)獨(dú)立的主題和功能點(diǎn),比如登錄頁面,注冊頁面,管理頁面,如是。在每個(gè)頁面里面,會(huì)放一些鏈接,已實(shí)現(xiàn)功能點(diǎn)的串聯(lián),有的鏈接點(diǎn)了,刷,跑到同一站點(diǎn)
3、的另一個(gè)頁面去了;有的鏈接點(diǎn)了,啾,可能跳到其他網(wǎng)站的頁面去;還有的鏈接點(diǎn)了,恩...,這次沒跑,但當(dāng)前頁面的樣子可能有所變化了。這些模式,和Activity給人的感覺很像,只不過實(shí)現(xiàn)策略不同罷了,畢竟Android這套架構(gòu)的核心思想,本身就來自源于Web的Mash-Up概念,視為頁面的客戶端化,也未嘗不可。Activity,在四大組件中,無疑是最復(fù)雜的,這年頭,一樣?xùn)|西和界面掛上了勾,都簡化不了,想一想,獨(dú)立做一個(gè)應(yīng)用有多少時(shí)間淪落在了界面上,就能琢磨清楚了。從視覺效果來看,一個(gè)Activity占據(jù)當(dāng)前的窗口,響應(yīng)所有窗口事件,具備有控件,菜
4、單等界面元素。從內(nèi)部邏輯來看,Activity需要為了保持各個(gè)界面狀態(tài),需要做很多持久化的事情,還需要妥善管理生命周期,和一些轉(zhuǎn)跳邏輯。對于開發(fā)者而言,就需要派生一個(gè)Activity的子類,然后埋頭苦干上述事情。對于Activity的更多細(xì)節(jié),先可以參見:reference/android/app/Activity.html。后續(xù),會(huì)獻(xiàn)上更為詳盡的剖析。Service服務(wù),從最直白的視角來看,就是剝離了界面的Activity,它們在很多Android的概念方面比較接近,都是封裝有一個(gè)完整的功能邏輯實(shí)現(xiàn),只不過Service不拋頭露臉,只是默默無
5、聲的做堅(jiān)實(shí)的后盾。但其實(shí),換個(gè)角度來看,Android中的服務(wù),和我們通常說的Windows服務(wù),Web的后臺(tái)服務(wù)又有一些相近,它們通常都是后臺(tái)長時(shí)間運(yùn)行,接受上層指令,完成相關(guān)事務(wù)的模塊。用運(yùn)行模式來看,Activity是跳,從一個(gè)跳到一個(gè),呃...,這有點(diǎn)像模態(tài)對話框(或者還像web頁面好了...),給一個(gè)輸入(抑或沒有...),然后不管不顧的讓它運(yùn)行,離開時(shí)返回輸出(同抑或沒有...)。而Service不是,它是等,等著上層連接上它,然后產(chǎn)生一段持久而纏綿的通信,這就像一個(gè)用了Ajax頁面,看著沒啥變化,偷偷摸摸的和Service不知眉來
6、眼去多少回了。但和一般的Service還是有所不同,Android的Service和所有四大組件一樣,其進(jìn)程模型都是可以配置的,調(diào)用方和發(fā)布方都可以有權(quán)利來選擇是把這個(gè)組件運(yùn)行在同一個(gè)進(jìn)程下,還是不同的進(jìn)程下。這句話,可以拿把指甲刀刻進(jìn)腦海中去,它凸顯了Android的運(yùn)行特征。如果一個(gè)Service,是有期望運(yùn)行在于調(diào)用方不同進(jìn)程的時(shí)候,就需要利用Android提供的RPC機(jī)制,為其部署一套進(jìn)程間通信的策略。Android的RPC實(shí)現(xiàn),如上圖所示(好吧,也是從SDK中拿來主義的...),無甚稀奇,基于代理模式的一個(gè)實(shí)現(xiàn),在調(diào)用端和服務(wù)端都去生
7、成一個(gè)代理類,做一些序列化和反序列化的事情,使得調(diào)用端和服務(wù)器端都可以像調(diào)用一個(gè)本地接口一樣使用RPC接口。Android中用來做數(shù)據(jù)序列化的類是Parcel,參見:/reference/android/os/Parcel.html,封裝了序列化的細(xì)節(jié),向外提供了足夠?qū)ο蠡脑L問接口,Android號稱實(shí)現(xiàn)非常高效。還有就是AIDL(AndroidInterfaceDefinitionLanguage),一種接口定義的語言,服務(wù)的RPC接口,可以用AIDL來描述,這樣,ADT就可以幫助你自動(dòng)生成一整套的代理模式需要用到的類,都是想起來很乏力寫起
8、來很苦力的那種。更多內(nèi)容,可以再看看:guide/developing/tools/aidl.html,如果有興致,可以找些其他PRC實(shí)現(xiàn)的資料lou