溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

百度百科對Intent的解析

發(fā)布時間:2020-07-30 08:07:00 來源:網(wǎng)絡(luò) 閱讀:202 作者:zhukev 欄目:移動開發(fā)


ntent

Intent(意圖)主要是解決Android應(yīng)用的各項組件之間的通訊。
Intent負責對應(yīng)用中一次操作的動作、動作涉及數(shù)據(jù)、附加數(shù)據(jù)進行描述,Android則根據(jù)此Intent的描述,負責找到對應(yīng)的組件,將 Intent傳遞給調(diào)用的組件,并完成組件的調(diào)用。
因此,Intent在這里起著一個媒體中介的作用,專門提供組件互相調(diào)用的相關(guān)信息,實現(xiàn)調(diào)用者與被調(diào)用者之間的解耦。
例如,在一個聯(lián)系人維護的應(yīng)用中,當我們在一個聯(lián)系人列表屏幕(假設(shè)對應(yīng)的Activity為listActivity)上,點擊某個聯(lián)系人后,希望能夠跳出此聯(lián)系人的詳細信息屏幕(假設(shè)對應(yīng)的Activity為detailActivity)
為了實現(xiàn)這個目的,listActivity需要構(gòu)造一個 Intent,這個Intent用于告訴系統(tǒng),我們要做“查看”動作,此動作對應(yīng)的查看對象是“某聯(lián)系人”,然后調(diào)用startActivity (Intent intent),將構(gòu)造的Intent傳入,系統(tǒng)會根據(jù)此Intent中的描述,到ManiFest中找到滿足此Intent要求的Activity,系統(tǒng)會調(diào)用找到的 Activity,即為detailActivity,最終傳入Intent,detailActivity則會根據(jù)此Intent中的描述,執(zhí)行相應(yīng)的操作。

一、Intent的抽象描述要描述什么

在Android參考文檔中,對Intent的定義是執(zhí)行某操作的一個抽象描述(確實很抽象)。我們先來看看這里的抽象描述,到底描述了什么。
首先,是要執(zhí)行的動作(action)的一個簡要描述,如VIEW_ACTION(查看)、EDIT_ACTION(修改)等,Android為我們定義了一套標準動作:
MAIN_ACTION
VIEW_ACTION
EDIT_ACTION
PICK_ACTION
GET_CONTENT_ACTION
DIAL_ACTION
CALL_ACTION
SENDTO_ACTION
ANSWER_ACTION
INSERT_ACTION
DELETE_ACTION
RUN_ACTION
LOGIN_ACTION
CLEAR_CREDENTIALS_ACTION
SYNC_ACTION
PICK_ACTIVITY_ACTION
WEB_SEARCH_ACTION
此外,我們還可以根據(jù)應(yīng)用的需要,定義我們自己的動作,并可定義相應(yīng)的Activity來處理我們的自定義動作。
其次,是執(zhí)行動作要操作的數(shù)據(jù)(data),Android中采用指向數(shù)據(jù)的一個URI來表示,如在聯(lián)系人應(yīng)用中,一個指向某聯(lián)系人的URI可能為:content://contacts/1。
這種URI表示,通過 ContentURI這個類來描述,具體可以參考android.net.ContentURI類的文檔。
以聯(lián)系人應(yīng)用為例,以下是一些action / data對,及其它們要表達的意圖:
VIEW_ACTION content://contacts/1-- 顯示標識符為"1"的聯(lián)系人的詳細信息
EDIT_ACTION content://contacts/1-- 編輯標識符為"1"的聯(lián)系人的詳細信息
VIEW_ACTION content://contacts/-- 顯示所有聯(lián)系人的列表
PICK_ACTION content://contacts/-- 顯示所有聯(lián)系人的列表,并且允許用戶在列表中選擇一個聯(lián)系人,然后把這個聯(lián)系人返回給父activity。例如:電子郵件客戶端可以使用這個Intent,要求用戶在聯(lián)系人列表中選擇一個聯(lián)系人
另外,除了action和data這兩個重要屬性外,還有一些附加屬性:
category(類別),被執(zhí)行動作的附加信息。例如 LAUNCHER_CATEGORY 表示Intent 的接受者應(yīng)該在Launcher中作為頂級應(yīng)用出現(xiàn);而ALTERNATIVE_CATEGORY表示當前的Intent是一系列的可選動作中的一個,這些動作可以在同一塊數(shù)據(jù)上執(zhí)行。
type(數(shù)據(jù)類型),顯式指定Intent的數(shù)據(jù)類型(MIME)。一般Intent的數(shù)據(jù)類型能夠根據(jù)數(shù)據(jù)本身進行判定,但是通過設(shè)置這個屬性,可以強制采用顯式指定的類型而不再進行推導。
component(組件),指定Intent的的目標組件的類名稱。通常 Android會根據(jù)Intent 中包含的其它屬性的信息,比如action、data/type、category進行查找,最終找到一個與之匹配的目標組件。但是,如果 component這個屬性有指定的話,將直接使用它指定的組件,而不再執(zhí)行上述查找過程。指定了這個屬性以后,Intent的其它所有屬性都是可選的。
extras(附加信息),是其它所有附加信息的集合。使用extras可以為組件提供擴展信息,比如,如果要執(zhí)行“發(fā)送電子郵件”這個動作,可以將電子郵件的標題、正文等保存在extras里,傳給電子郵件發(fā)送組件。
總之,action、 data/type、category和extras 一起形成了一種語言。
這種語言使系統(tǒng)能夠理解諸如“查看某聯(lián)系人的詳細信息”之類的短語。隨著應(yīng)用不斷的加入到系統(tǒng)中,它們可以添加新的action、 data/type、category來擴展這種語言。應(yīng)用也可以提供自己的Activity來處理已經(jīng)存在的這樣的“短語”,從而改變這些“短語”的行為。

2二、Android如何解析Intent

在應(yīng)用中,我們可以以兩種形式來使用Intent:
直接Intent:指定了component屬性的Intent(調(diào)用setComponent(ComponentName)或者setClass(Context, Class)來指定)。通過指定具體的組件類,通知應(yīng)用啟動對應(yīng)的組件。
間接Intent:沒有指定component屬性的Intent。這些Intent需要包含足夠的信息,這樣系統(tǒng)才能根據(jù)這些信息,在在所有的可用組件中,確定滿足此Intent的組件。
對于直接Intent,Android不需要去做解析,因為目標組件已經(jīng)很明確,Android需要解析的是那些間接Intent,通過解析,將 Intent映射給可以處理此Intent的Activity、IntentReceiver或Service。
Intent解析機制主要是通過查找已注冊在AndroidManifest.xml中的所有IntentFilter及其中定義的Intent,最終找到匹配的Intent。在這個解析過程中,Android是通過Intent的action、type、category這三個屬性來進行判斷的,判斷方法如下:
如果Intent指明定了action,則目標組件的IntentFilter的action列表中就必須包含有這個action,否則不能匹配;如果Intent沒有提供type,系統(tǒng)將從data中得到數(shù)據(jù)類型。和action一樣,目標組件的數(shù)據(jù)類型列表中必須包含Intent的數(shù)據(jù)類型,否則不能匹配。
如果Intent中的數(shù)據(jù)不是content: 類型的URI,而且Intent也沒有明確指定它的type,將根據(jù)Intent中數(shù)據(jù)的scheme (比如 http: 或者mailto: ) 進行匹配。同上,Intent 的scheme必須出現(xiàn)在目標組件的scheme列表中。
如果Intent指定了一個或多個category,這些類別必須全部出現(xiàn)在組建的類別列表中。比如Intent中包含了兩個類別:LAUNCHER_CATEGORY 和 ALTERNATIVE_CATEGORY,解析得到的目標組件必須至少包含這兩個類別。

3三、Intent的顯式調(diào)用和隱式調(diào)用

顯式Intent直接用組件的名稱定義目標組件,這種方式很直接。但是由于開發(fā)人員往往并不清楚別的應(yīng)用程序的組件名稱,因此,顯式Intent更多用于在應(yīng)用程序內(nèi)部傳遞消息。比如在某應(yīng)用程序內(nèi),一個Activity啟動一個Service。
隱式Intent恰恰相反,它不會用組件名稱定義需要激活的目標組件,它更廣泛地用于在不同應(yīng)用程序之間傳遞消息。
在顯式Intent消息中,決定目標組件的唯一要素就是組件名稱,因此,如果你的Intent中已經(jīng)明確定義了目標組件的名稱,那么你就完全不用再定義其他Intent內(nèi)容。
而對于隱式Intent則不同,由于沒有明確的目標組件名稱,所以必須由Android系統(tǒng)幫助應(yīng)用程序?qū)ふ遗cIntent請求意圖最匹配的組件。
(Intent定義:Intent是一種在不同組件之間傳遞的請求消息,是應(yīng)用程序發(fā)出的請求和意圖。作為一個完整的消息傳遞機制,Intent不僅需要發(fā)送端,還需要接收端。
顯式Intent定義:對于明確指出了目標組件名稱的Intent,我們稱之為顯式Intent。
隱式Intent定義:對于沒有明確指出目標組件名稱的Intent,則稱之為隱式Intent。
說明:Android系統(tǒng)使用IntentFilter來尋找與隱式Intent相關(guān)的對象。
顯式Intent直接用組件的名稱定義目標組件,這種方式很直接。但是由于開發(fā)人員往往并不清楚別的應(yīng)用程序的組件名稱,因此,顯式Intent更多用于在應(yīng)用程序內(nèi)部傳遞消息。比如在某應(yīng)用程序內(nèi),一個Activity啟動一個Service。
隱式Intent恰恰相反,它不會用組件名稱定義需要激活的目標組件,它更廣泛地用于在不同應(yīng)用程序之間傳遞消息。
在顯式Intent消息中,決定目標組件的唯一要素就是組件名稱,因此,如果你的Intent中已經(jīng)明確定義了目標組件的名稱,那么你就完全不用再定義其他Intent內(nèi)容。
而對于隱式Intent則不同,由于沒有明確的目標組件名稱,所以必須由Android系統(tǒng)幫助應(yīng)用程序?qū)ふ遗cIntent請求意圖最匹配的組件。
Android系統(tǒng)尋找與Intent請求意圖最匹配的組件具體的選擇方法 是:Android將Intent的請求內(nèi)容和一個叫做IntentFilter的過濾器比較,IntentFilter中包含系統(tǒng)中所有可能的待選組件。
如果IntentFilter中某一組件匹配隱式Intent請求的內(nèi)容,那么Android就選擇該組件作為該隱式Intent的目標組件。
Android如何知道應(yīng)用程序能夠處理某種類型的Intent請求呢?這需要應(yīng)用程序在Android-Manifest.xml中聲明自己所含組件的過濾器(即可以匹配哪些Intent請求)。
一個沒有聲明Intent-Filter的組件只能響應(yīng)指明自己名字的顯式Intent請求,而無法響應(yīng)隱式Intent請求。
而一個聲明了IntentFilter的組件既可以響應(yīng)顯式Intent請求,也可以響應(yīng)隱式Intent請求。在通過和 IntentFilter比較來解析隱式Intent請求時,Android將以下三個因素作為選擇的參考標準:
Action
Data
Category
而Extra和Flag在解析收到Intent時是并不起作用的。
向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI