成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android消息傳遞應用功能解析

移動開發 Android
Android消息傳遞是一個基于Intent的核心機制。大家可以通過這篇文章中介紹的內容充分掌握這一機制的應用方式。

Android手機操作系統中有一種叫做Intent的消息傳遞機制。這在實際編程中是一個核心技術,值得我們去深入的研究。在這里大家將會了解到有關Android消息傳遞的一些基礎應用技巧,幫助大家理解。#t#

每一個Cursor、ContentResolver做為一個小的注冊中心,相關觀察者可以在這個中心注冊,更新消息由注冊中心分發給各個觀察者。而在MFC或Winform中,都會形成一個消息網,讓消息在網中流動,被各節點使用、吃掉或者在出口死掉。

相比之下,我個人覺得基于Intent的Android消息傳遞機制是有所不同的。它應該會有一個全局性的注冊中心,這個注冊中心是隱性的,整個Android系統中就那么一個。所有的消息接收者,都被隱形的注冊到這個中心。包括Activity,Service和IntentReceiver。其實說隱形注冊是不確切的,所有注冊都還是我們手動告訴注冊中心的,只是與傳統的方式不一樣,我們通常不是通過代碼,而是通過配置文件來做。在應用的Manifest中,我們會為一些Activity或Service添加上Intent-filter,或在配置文件中添加<receiver></receiver>項。這其實就相當于向系統的注冊中心注冊了相關的Intent-filter和receiver(這個事情完全可以通過代碼來做,只是這樣就失去了修改的靈活性)。

當程序有一個消息希望發出去的時候,它需要將消息封裝成一個Intent,并發送。這時候,應該是有一個統一的中心(恩,有可能Android底層實現的時候不是,但簡單這樣看是沒問題的...)接受到這個消息,并對它進行解析、判定消息類型(這個步驟降低了耦合...),然后檢查注冊了相匹配的filter或receiver,并創建或喚醒接收者,將消息分發給它。這樣做有很多好處。雖然這種傳遞有的時候不如點對點的傳遞快(這有些需要速度的地方,我們看到Android會通過直接通信來做),但有時候又因為它只經過一跳(姑且這么叫吧...),比復雜的流動又要更快。

更重要的是,它耦合性低,在手機平臺這種程序組件多變的條件下使用十分適合。并且它可以很容易實現消息的精確或模糊匹配,彈性很大。(我個人曾想在開發一個C++二次平臺的時候引入這樣的機制,但在C++中,建立一套完整的數據marshal機制不容易,相比之下,用java來做會簡單很多...)

恩,廢話說了很多,具體講講Android消息傳遞中Intent的使用。當你有一個消息需要傳遞,如果你明確知道你需要哪個Activity或者其他Class來響應的話,你可以指定這個類來接受該消息,這被稱為顯性發送。你需要將Intent的class屬性設置成目標。這種情況很常見,比如startActivity的時候,會清楚當前Activity完了應該是哪個Activity,那就明確的發送這個消息。

但是,有的時候你并不確定你的消息是需要具體哪個類來執行,而只是知道接收者該符合哪些條件。比如你只需要有一個接收者能顯示用戶所選的數據,而不想制定某個具體的方法,這時候你就需要用到隱形發送(傳統上,我們可能會考慮用多態,但顯然這種方式更為靈活...)。

在Android中,你可以為Intent指定一個action,表示你這個指令需要處理的事情。系統為我們定義了很多Action類型,這些類型使系統與我們通信的語言(比如在Activity里面加一個Main的filter,該activity就會做成該應用的入口點),當然你也可以用于你自己的應用之間的通信(同樣當然,也可以自定義...)。強烈建議,在自己程序接收或發出一個系統action的時候,要名副其實。比如你響應一個view動作,做的確實edit的勾當,你發送一個pick消息,其實你想讓別人做edit的事,這樣都會造成混亂。

當然只有Action有時候是不夠的,在Android中我們還可以指定catalog信息和type/data信息,比如所有的顯示數據的Activity,可能都會響應View action。但很多與我們需要顯示的數據類型不一樣,可以加一個type信息,明確的指出我們需要顯示的數據類型,甚至還可以加上一個catalog信息,指明只有你只有按的是“中鍵”并發出這樣的消息才響應。

從上面可以看出,Android的Intent可以添加上class, action, data/type, catalog等消息,注冊中心會根據這些信息幫你找到符合的接收者。其中class是點對點的指示,一旦指明,其他信息都被忽略。Intent中還可以添加key/value的數據,發送方和接收方需要保持統一的key信息和value類型信息,這種數據的marshal在java里做,是不費什么力氣的。

Android消息傳遞的Intent發送,可以分成單播和廣播兩種。廣播的接收者是所有注冊了的符合條件的IntentReceiver。在單播的情況下,即使有很多符合條件的接收者,也只要有一個出來處理這個消息就好(恩,個人看法,沒找到確切條款或抉擇的算法,本來想實驗一下,沒來得及...),這樣的情況很容易理解,當你需要修改某個數據的時候,你肯定不會希望有十個編輯器輪流讓你來處理。當廣播不是這樣,一個receiver沒有辦法阻止其他receiver進行對廣播事件的處理。這種情況也很容易理解,比如時鐘改變了,鬧鐘、備忘錄等很多程序都需要分別進行處理。在自己的程序的使用中,應該分清楚區別,合理的使用。

責任編輯:曹凱 來源: 博客園
相關推薦

2010-02-26 10:56:06

WCF Stream

2013-09-02 16:04:20

Windows

2010-02-25 16:12:23

WCF IDispos

2010-02-23 10:15:22

WCF運行機制

2010-02-22 15:00:02

WCF信道工廠

2011-02-24 11:10:40

2009-10-26 10:42:23

惠普IAP集成歸檔平臺

2009-10-21 18:07:55

信息歸檔IAP

2009-02-01 15:13:08

2013-04-03 14:01:25

網絡自動化自動化編排技術功能解析

2010-05-31 15:49:29

MySQL臨時表

2017-11-07 22:19:55

iOS 蘋果App

2010-03-02 17:43:31

WCF框架處理流程

2011-11-16 10:18:43

IP地址IP地址管理

2010-02-03 09:58:33

全光交換機

2009-12-23 17:31:56

WPF Style

2013-04-24 11:15:56

Android開發Touch事件傳遞機制

2019-09-04 14:30:54

Nginx功能服務器

2020-04-09 16:49:32

Apple Pay支付交通

2013-04-25 09:53:01

Windows Ser
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精久久久 | www..99re| 黄网站在线播放 | 黄色大片免费播放 | 成人精品国产免费网站 | 福利视频网址 | 久久久久久久一区 | 中文字幕动漫成人 | 日韩中文字幕在线播放 | 亚洲精品久久久蜜桃网站 | 久久毛片| 日韩精品一区二区三区中文在线 | 九九热精品在线 | 黄色大片免费看 | 欧美一区二区精品 | 仙人掌旅馆在线观看 | 操人网站 | 成人精品视频在线观看 | 中文字幕成人av | 午夜三区 | 91社区在线观看 | 青青草原精品99久久精品66 | 国产乱码精品一区二区三区中文 | 日本精品一区二区 | 欧美一区| 成人亚洲 | 久久国产日本 | 91国在线观看 | 精品中文字幕久久 | 久久久久久国产精品 | 久久久久久影院 | 91精品国产欧美一区二区 | 2018中文字幕第一页 | 国产午夜精品久久久久免费视高清 | 九九九视频 | 亭亭五月激情 | 精品av | 可以免费观看的av片 | av中文在线 | 国产 欧美 日韩 一区 | 亚洲精品av在线 |