標籤:des android style color io os 使用 ar java
1.請談一下Android系統的架構。
答:Android系統採用了分層架構,從高層到低層分別是應用程式層、應用程式架構層、系統運行庫層和linux核心層。
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檔案:
張三 22
李四 23
定義一個名為Person的javaBean用於存放上面解析出來的xml內容
public class 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;
}
public void setName(String name) {
this.name = name;
}
public Short getAge() {
return age;
}
public void 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;
public class PersonDefaultHandler extends DefaultHandler {
private List persons;
private Person person ; //記錄當前person
private String perTag; //記錄前一個標籤的名稱
/**
* 重寫父類的開始文檔方法。用於初始化
*/
@Override
public void startDocument() throws SAXException {
persons = new ArrayList();
}
@Override
public void 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;
}
/**參數:
* ch 整個XML字串
* start 節點值在整個XML字串中的索引位置
* length-節點值的長度
*/
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
if(perTag!=null){
String data = new String(ch,start,length);
if(“name”.equals(perTag)){
person.setName(data);
}else if(“age”.equals(perTag)){
person.setAge(new Short(data));
}
}
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
if(“person”.equals(localName)){
persons.add(person);
person = null;
}
perTag = null;
}
public List getPersons() {
return persons;
}
}
SAXPerson.java
import java.io.InputStream;
import java.util.List;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import com.sinber.domain.Person;
public class SAXPerson{
public static List getPerson() throws Exception{
//通過類裝載器擷取檔案
InputStream inStream = SAXPersonService.class.getClassLoader().getResourceAsStream(“person.xml”);
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
PersonDefaultHandler handler = new PersonDefaultHandler();
saxParser.parse(inStream, handler);
inStream.close();
return handler.getPersons();
}
}
(2)DOM解析XML檔案時,會將XML檔案的所有內容讀取到記憶體中,然後允許您使用DOM API遍曆XML樹、檢索所需的資料。
DOMPerson.java
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import com.sinber.domain.Person;
public class DOMPerson {
public static List getPerson() throws Exception{
List pers = new ArrayList();
InputStream inStream = SAXPersonService.class.getClassLoader().getResourceAsStream(“person.xml”);
DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document dom = builder.parse(inStream);
Element root = dom.getDocumentElement();
NodeList persons = root.getElementsByTagName(“person”);
for(int i=0;i<persons.getLength();i++){
Element personNode =(Element)persons.item(i);
Person person = new Person();
person.setId(new Integer(personNode.getAttribute("id")));
NodeList childNodes = personNode.getChildNodes();
for(int j=0;j<childNodes.getLength();j++){
Node childNode = childNodes.item(j);
if(childNode.getNodeType()==Node.ELEMENT_NODE){
Element element = (Element)childNode;
if("name".equals(childNode.getNodeName())){
person.setName(new String(element.getFirstChild().getNodeValue()));
}else if("age".equals(childNode.getNodeName())){
person.setAge(new Short(element.getFirstChild().getNodeValue()));
}
}
}
pers.add(person);
}
inStream.close();
return pers;
}
}
(3)使用Pull解析器讀取XML檔案
PullPerson.java
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlSerializer;
import android.os.Environment;
import android.util.Xml;
import com.sinber.domain.Person;
public class PullPerson {
public static void save(List persons) throws Exception{
XmlSerializer serializer = Xml.newSerializer();
File file = new File(Environment.getExternalStorageDirectory(),”person.xml”);
FileOutputStream outStream = new FileOutputStream(file);
serializer.setOutput(outStream,”UTF-8″);
serializer.startDocument(“UTF-8″, true);
serializer.startTag(“”, “persons”);
for(Person person:persons){
serializer.startTag(“”, “person”); //person
serializer.attribute(“”, “id”, “”+person.getId());
serializer.startTag(“”, “name”); //name
serializer.text(person.getName());
serializer.endTag(“”, “name”); //name
serializer.startTag(“”, “age”); //age
serializer.text(person.getAge().toString());
serializer.endTag(“”, “age”);//age
serializer.endTag(“”, “person”); //person
}
serializer.endTag(“”, “persons”);
serializer.endDocument();
outStream.close();
}
public static List getPersons() throws Exception{
List persons = null;
Person person = null;
XmlPullParser parser= Xml.newPullParser();
InputStream inStream = PullPersonService.class.getClassLoader().getResourceAsStream(“person.xml”);
parser.setInput(inStream, “UTF-8″);
int eventType = parser.getEventType(); //觸發第一個事件
while(eventType!=XmlPullParser.END_DOCUMENT){
switch(eventType){
case XmlPullParser.START_DOCUMENT:
persons = new ArrayList();
break;
case XmlPullParser.START_TAG: //開始元素事件
if(“person”.equals(parser.getName())){
person = new Person();
person.setId(new Integer(parser.getAttributeValue(0)));
}else if(person!=null){
if(“name”.equals(parser.getName())){
person.setName(parser.nextText());
}else if(“age”.equals(parser.getName())){
person.setAge(new Short(parser.nextText()));
}
}
break;
case XmlPullParser.END_TAG: //結束元素事件
if(“person”.equals(parser.getName())){
persons.add(person);
person = null;
}
break;
default:
break;
}
eventType = parser.next();
}
return persons;
}
}
以上三種方式任選其一即可。
9.根據自己的理解描述下Android數位簽章。
答:
(1)所有的應用程式都必須有數位憑證,Android系統不會安裝一個沒有數位憑證的應用程式
(2)Android程式包使用的數位憑證可以是自簽名的,不需要一個權威的數位憑證機構簽名認證
(3)如果要正式發布一個Android ,必須使用一個合適的私密金鑰產生的數位憑證來給程式簽名,而不能使用adt外掛程式或者ant工具產生的調試認證來發布。
(4)數位憑證都是有有效期間的,Android只是在應用程式安裝的時候才會檢查認證的有效期間。如果程式已經安裝在系統中,即使認證到期也不會影響程式的正常功能。
10.已知單鏈表的頭結構head,寫一個函數把這個鏈表逆序。
答: 如下所示
Node.java
public class Node {
private Integer count;
private Node nextNode;
public Node(){
}
public Node(int count){
this.count = new Integer(count);
}
public Integer getCount() {
return count;
}
public void setCount(Integer count) {
this.count = count;
}
public Node getNextNode() {
return nextNode;
}
public void setNextNode(Node nextNode) {
this.nextNode = nextNode;
}
}
ReverseSingleLink.java
public class ReverseSingleLink {
public static Node revSingleLink(Node head){
if(head == null){ //鏈表為空白不能逆序
return head;
}
if(head.getNextNode()==null){ //如果只有一個結點,當然逆過來也是同一個
return head;
}
Node rhead = revSingleLink(head.getNextNode());
head.getNextNode().setNextNode(head);
head.setNextNode(null);
return rhead;
}
public static void main(String[] args){
Node head = new Node(0);
Node temp1 = null,temp2 = null;
for(int i=1;i<100;i++){
temp1 = new Node(i);
if(i==1){
head.setNextNode(temp1);
}else{
temp2.setNextNode(temp1);
}
temp2 = temp1;
}
head = revSingleLink(head);
while(head!=null){
head = head.getNextNode();
}
}
}
android筆試題集2