編輯:關於Android編程
在Mms中每個Thread都有其相應的聯系人,但是threads表中並沒有直接保存聯系人的信息(號碼或名字),而是保存一個叫做recipient_id的東西,也還有一個類叫做data/RecipientIdCache.java專門管理它。
在數據庫中專門有一個表來保存它canonical_addresses。它的目的就是為了能夠快速的找到某一對話的聯系人的信息。對話的表threads裡面並沒有保存其聯系人的直接信息,而是有一列叫做recipient_ids的整數來代表收信人。而在數據庫還有另外一個表叫做canonical_addresses,其用來匹配threads中的recipient_ids和號碼,其只有二列,一個是_id,另一個就是它的號碼。因為對話中並沒有直接保存聯系人的信息,所以當ConversationList想要顯示一個Thread時,就要先查到它的RecipientId,然後再根據這個RecipientId到canonical_addresses中查找到號碼,再用這個號碼去聯系人數據庫查詢到聯系人的其他信息。這一整個過程比較煩瑣,需要要查詢三次數據庫才能得到聯系人的信息,就無法快速的顯示出來。所以就有了RecipientIdCache這個類,這個類內部有一個Hash表,鍵是Thread的RecipientId,值是聯系人的號碼。其他的類,比如Conversation在查詢Thread的時候不會直接去查詢canonical_addresses表來得到對應RecipientId的聯系人的號碼,而是直接通過RecipientIdCache來獲取。RecipientIdCache先從自己的Cache中來查到號碼,如果查找 不到再去查詢數據庫,並加到Cache中。每次發送信息時都會進行一次更新Cache的動作。因為RecipientId是Thread中的一個屬性,所以當Thread表發生變化時,比如刪除一個Thread時也都會進行更新RecipientIdCache。
一般SDK中都會帶有一些示例程序,說明具體用法,Android SDK也是如此。它提供了一些ApiDemo示例,詳細說明了Android中主要API,分為以
通常情況下,Android實現自定義控件無非三種方式。 Ⅰ、繼承現有控件,對其控件的功能進行拓展。 Ⅱ、將現有控件進行組合,實現功能更加強大控件。 Ⅲ、重寫View
在Android的3.0之後,google又提出了屬性動畫的這樣一個框架,他可以更好的幫助我們實現更豐富的動畫效果。所以為了跟上技術的步伐,今天就聊一聊屬性動畫。這一次的
類概述Android裡Scroller類是為了實現View平滑滾動的一個Helper類。通常在自定義的View時使用,在View中定義一個私有成員mScroller =