Android筆試總結 前端
筆試總結 java
筆試,共10道題,不限時間。(答案整理自互聯網,不保證徹底正確,僅供參考。) linux
1.請談一下Android系統的架構。 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文件:
<?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內容
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<Person> persons;
private Person person ; //記錄當前person
private String perTag; //記錄前一個標籤的名稱
/**
* 重寫父類的開始文檔方法。用於初始化
*/
@Override
public void startDocument() throws SAXException {
persons = new ArrayList<Person>();
}
@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<Person> 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<Person> 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<Person> getPerson() throws Exception{
List<Person> pers = new ArrayList<Person>();
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<Person> 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<Person> getPersons() throws Exception{
List<Person> 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<Person>();
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(); } } }