Android架構分4層 用框行li (諧音:用框行禮)
Android布局有5種 架線絕對表 (諧音:架電線絕對需要用表)
資料存儲5方式 下賤似C網 (諧音:下賤的就是聯通CDMA網 sharePreferences、檔案、SQLite、ContentProvider、網絡存儲)
AICS 動意内務 (諧音 動意内務)
吾師哥 View, surfaceView, GLSurfaceView (諧音 吾師哥 )
能适應Adapter ABC,HLRSSSW (ABC,哈兒日思,思數萬) 一系列基本的光頭,列出的資源簡單簡單誘餌性包裝。
1.請談一下Android系統的架構。
答:Android系統采用了分層架構,從高層到低層分别是應用程式層、應用程式架構層、系統運作庫層和linux核心層。
android 愛pk aapt
布局:架線絕對表;
設想:用框行li;
資料:下賤似C網;
我有:吾師哥 ;
核心:動意内務;
能适應Adapter;
一系列基本的光頭,列出的資源簡單簡單誘餌性包裝;
威武我的衣;
剛開始的時候,邦德儲存實力狀态 onCreate(Bundle savedInstanceState)
2.談談android大衆常用的五種布局。
答:在Android中,共有五種布局方式,分别是:FrameLayout(架構布局),LinearLayout (線性布局),AbsoluteLayout(絕對布局),RelativeLayout(相對布局),TableLayout(表格布局)。
(1)FrameLayout 架構布局,放入其中的所有元素都被放置在最左上的區域,而且無法為這些元素指定一個确切的位置,下一個子元素會重疊覆寫上一個子元素,适合浏覽單張圖檔。
(2)LinearLayout 線性布局,是應用程式中最常用的布局方式,主要提供控件水準或者垂直排列的模型,每個子元件都是以垂直或水準的方式來定位.(預設是垂直)
(3)AbsoluteLayout 絕對定位布局,采用坐标軸的方式定位元件,左上角是(0,0)點,往右x軸遞增,往下Y軸遞增,元件定位屬性為android:layout_x 和 android:layout_y來确定坐标。
(4)RelativeLayout 相對布局,根據另外一個元件或是頂層父元件來确定下一個元件的位置。和CSS裡面的類似。
(5)TableLayout 表格布局,類似Html裡的Table.使用TableRow來布局,其中TableRow代表一行,TableRow的每一個視圖元件代表一個單元格。
3.談談android資料存儲方式。
答:Android提供了5種方式存儲資料:
(1)使用SharedPreferences存儲資料;它是Android提供的用來存儲一些簡單配置資訊的一種機制,采用了XML格式将資料存儲到裝置中。隻能在同一個包内使用,不能在不同的包之間使用。
(2)檔案存儲資料;檔案存儲方式是一種較常用的方法,在Android中讀取/寫入檔案的方法,與Java中實作I/O的程式是完全一樣的,提供了openFileInput()和openFileOutput()方法來讀取裝置上的檔案。
(3)SQLite資料庫存儲資料;SQLite是Android所帶的一個标準的資料庫,它支援SQL語句,它是一個輕量級的嵌入式資料庫。
(4)使用ContentProvider存儲資料;主要用于應用程式之間進行資料交換,進而能夠讓其他的應用儲存或讀取此Content Provider的各種資料類型。
(5)網絡存儲資料;通過網絡上提供給我們的存儲空間來上傳(存儲)和下載下傳(擷取)我們存儲在網絡空間中的資料資訊。
4.Android中Activity, Intent, Content Provider, Service各有什麼差別。
答:Activity: 活動,是最基本的android應用程式元件。一個活動就是一個單獨的螢幕,每一個活動都被實作為一個獨立的類,并且從活動基類繼承而來。
Intent: 意圖,描述應用想幹什麼。最重要的部分是動作和動作對應的資料。
Content Provider:内容提供器,android應用程式能夠将它們的資料儲存到檔案、SQLite資料庫中,甚至是任何有效的裝置中。當你想将你的應用資料和其他應用共享時,内容提供器就可以發揮作用了。
Service:服務,具有一段較長生命周期且沒有使用者界面的程式。
5.View, surfaceView, GLSurfaceView有什麼差別。
答:view是最基礎的,必須在UI主線程内更新畫面,速度較慢。
SurfaceView 是view的子類,類似使用雙緩機制,在新的線程中更新畫面是以重新整理界面速度比view快
GLSurfaceView 是SurfaceView的子類,opengl 專用的
6.Adapter有什麼作用?常見的Adapter有哪些?
答:Adapter是連接配接後端資料和前端顯示的擴充卡接口。常見的Adapter有ArrayAdapter, BaseAdapter, CursorAdapter, HeaderViewListAdapter, ListAdapter, ResourceCursorAdapter, SimpleAdapter, SimpleCursorAdapter, SpinnerAdapter, WrapperListAdapter等
7.Manifest.xml檔案中主要包括哪些資訊?
答:manifest:根節點,描述了package中所有的内容。
uses-permission:請求你的package正常運作所需賦予的安全許可。
permission: 聲明了安全許可來限制哪些程式能你package中的元件和功能。
instrumentation:聲明了用來測試此package或其他package指令元件的代碼。
application:包含package中application級别元件聲明的根節點。
activity:Activity是用來與使用者互動的主要工具。
receiver:IntentReceiver能使的application獲得資料的改變或者發生的操作,即使它目前不在運作。
service:Service是能在背景運作任意時間的元件。
provider:ContentProvider是用來管理持久化資料并釋出給其他應用程式使用的元件。
8.請寫一段代碼(SAX, DOM, 或者pull )來解析XML文檔。
答:下面是要解析的XML檔案:
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="1">
<name>張三</name>
<age>22</age>
</person>
<person id="2">
<name>李四</name>
<age>23</age>
</person>
</persons>
複制代碼
定義一個名為Person的javaBean用于存放上面解析出來的xml内容
publicclass Person {
private Integer id;
private String name;
private Short age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
publicvoid setName(String name) {
this.name = name;
}
public Short getAge() {
return age;
}
publicvoid setAge(Short age) {
this.age = age;
}
}
複制代碼
(1)使用SAX讀取XML檔案;它采用的是事件驅動,并不需要解析完整個文檔,速度快并且占用記憶體少。需要為SAX提供實作ContentHandler接口的類。
PersonDefaultHandler.java
import java.util.ArrayList;
import java.util.List;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import com.sinber.domain.Person;
publicclass PersonDefaultHandler extends DefaultHandler {
private List<Person> persons;
private Person person ; //記錄目前person
private String perTag; //記錄前一個标簽的名稱
@Override
publicvoid startDocument() throws SAXException {
persons =new ArrayList<Person>();
}
@Override
publicvoid startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
if("person".equals(localName)){
Integer id =new Integer(attributes.getValue(0)); //取id
person =new Person();
person.setId(id);
}
perTag = localName;
}