Android笔试.docx

上传人:b****7 文档编号:23842660 上传时间:2023-05-21 格式:DOCX 页数:13 大小:20.25KB
下载 相关 举报
Android笔试.docx_第1页
第1页 / 共13页
Android笔试.docx_第2页
第2页 / 共13页
Android笔试.docx_第3页
第3页 / 共13页
Android笔试.docx_第4页
第4页 / 共13页
Android笔试.docx_第5页
第5页 / 共13页
点击查看更多>>
下载资源
资源描述

Android笔试.docx

《Android笔试.docx》由会员分享,可在线阅读,更多相关《Android笔试.docx(13页珍藏版)》请在冰豆网上搜索。

Android笔试.docx

Android笔试

Android笔试总结

笔试,共10道题,不限时间。

(答案整理自互联网,不保证完全正确,仅供参考。

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存储数据;主要用于应用程序之间进行数据交换,从而能够让其他的应用保存或读取此ContentProvider的各种数据类型。

(5)网络存储数据;通过网络上提供给我们的存储空间来上传(存储)和下载(获取)我们存储在网络空间中的数据信息。

 

4.Android中Activity,Intent,ContentProvider,Service各有什么区别。

答:

Activity:

活动,是最基本的android应用程序组件。

一个活动就是一个单独的屏幕,每一个活动都被实现为一个独立的类,并且从活动基类继承而来。

Intent:

意图,描述应用想干什么。

最重要的部分是动作和动作对应的数据。

ContentProvider:

内容提供器,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文件:

xmlversion="1.0"encoding="UTF-8"?

>

张三

22

李四

23

定义一个名为Person的javaBean用于存放上面解析出来的xml内容

publicclassPerson{

privateIntegerid;

privateStringname;

privateShortage;

publicIntegergetId(){

returnid;

}

publicvoidsetId(Integerid){

this.id=id;

}

publicStringgetName(){

returnname;

}

publicvoidsetName(Stringname){

this.name=name;

}

publicShortgetAge(){

returnage;

}

publicvoidsetAge(Shortage){

this.age=age;

}

}

 

(1)使用SAX读取XML文件;它采用的是事件驱动,并不需要解析完整个文档,速度快并且占用内存少。

需要为SAX提供实现ContentHandler接口的类。

PersonDefaultHandler.java

importjava.util.ArrayList;

importjava.util.List;

importorg.xml.sax.Attributes;

importorg.xml.sax.SAXException;

importorg.xml.sax.helpers.DefaultHandler;

importcom.sinber.domain.Person;

publicclassPersonDefaultHandlerextendsDefaultHandler{

privateListpersons;

privatePersonperson;//记录当前person

privateStringperTag;//记录前一个标签的名称

/**

*重写父类的开始文档方法。

用于初始化

*/

@Override

publicvoidstartDocument()throwsSAXException{

persons=newArrayList();

}

@Override

publicvoidstartElement(Stringuri,StringlocalName,StringqName,

Attributesattributes)throwsSAXException{

if("person".equals(localName)){

Integerid=newInteger(attributes.getValue(0));//取id

person=newPerson();

person.setId(id);

}

perTag=localName;

}

/**参数:

*ch整个XML字符串

*start节点值在整个XML字符串中的索引位置

*length节点值的长度

*/

@Override

publicvoidcharacters(char[]ch,intstart,intlength)

throwsSAXException{

if(perTag!

=null){

Stringdata=newString(ch,start,length);

if("name".equals(perTag)){

person.setName(data);

}elseif("age".equals(perTag)){

person.setAge(newShort(data));

}

}

}

@Override

publicvoidendElement(Stringuri,StringlocalName,StringqName)

throwsSAXException{

if("person".equals(localName)){

persons.add(person);

person=null;

}

perTag=null;

}

publicListgetPersons(){

returnpersons;

}

}

SAXPerson.java

importjava.io.InputStream;

importjava.util.List;

importjavax.xml.parsers.SAXParser;

importjavax.xml.parsers.SAXParserFactory;

importcom.sinber.domain.Person;

publicclassSAXPerson{

publicstaticListgetPerson()throwsException{

//通过类装载器获取文件

InputStreaminStream=SAXPersonService.class.getClassLoader().getResourceAsStream("person.xml");

SAXParserFactoryfactory=SAXParserFactory.newInstance();

SAXParsersaxParser=factory.newSAXParser();

PersonDefaultHandlerhandler=newPersonDefaultHandler();

saxParser.parse(inStream,handler);

inStream.close();

returnhandler.getPersons();

}

}

 

(2)DOM解析XML文件时,会将XML文件的所有内容读取到内存中,然后允许您使用DOMAPI遍历XML树、检索所需的数据。

DOMPerson.java

 

importjava.io.InputStream;

importjava.util.ArrayList;

importjava.util.List;

importjavax.xml.parsers.DocumentBuilder;

importjavax.xml.parsers.DocumentBuilderFactory;

importorg.w3c.dom.Document;

importorg.w3c.dom.Element;

importorg.w3c.dom.Node;

importorg.w3c.dom.NodeList;

importcom.sinber.domain.Person;

publicclassDOMPerson{

publicstaticListgetPerson()throwsException{

Listpers=newArrayList();

InputStreaminStream=SAXPersonService.class.getClassLoader().getResourceAsStream("person.xml");

DocumentBuilderFactoryfactory=DocumentBuilderFactory.newInstance();

DocumentBuilderbuilder=factory.newDocumentBuilder();

Documentdom=builder.parse(inStream);

Elementroot=dom.getDocumentElement();

NodeListpersons=root.getElementsByTagName("person");

for(inti=0;i

ElementpersonNode=(Element)persons.item(i);

Personperson=newPerson();

person.setId(newInteger(personNode.getAttribute("id")));

NodeListchildNodes=personNode.getChildNodes();

for(intj=0;j

NodechildNode=childNodes.item(j);

if(childNode.getNodeType()==Node.ELEMENT_NODE){

Elementelement=(Element)childNode;

if("name".equals(childNode.getNodeName())){

person.setName(newString(element.getFirstChild().getNodeValue()));

}elseif("age".equals(childNode.getNodeName())){

person.setAge(newShort(element.getFirstChild().getNodeValue()));

}

}

}

pers.add(person);

}

inStream.close();

returnpers;

}

}

(3)使用Pull解析器读取XML文件

PullPerson.java

importjava.io.File;

importjava.io.FileOutputStream;

importjava.io.InputStream;

importjava.util.ArrayList;

importjava.util.List;

importorg.xmlpull.v1.XmlPullParser;

importorg.xmlpull.v1.XmlSerializer;

importandroid.os.Environment;

importandroid.util.Xml;

importcom.sinber.domain.Person;

publicclassPullPerson{

publicstaticvoidsave(Listpersons)throwsException{

XmlSerializerserializer=Xml.newSerializer();

Filefile=newFile(Environment.getExternalStorageDirectory(),"person.xml");

FileOutputStreamoutStream=newFileOutputStream(file);

serializer.setOutput(outStream,"UTF-8");

serializer.startDocument("UTF-8",true);

serializer.startTag("","persons");

for(Personperson:

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();

}

publicstaticListgetPersons()throwsException{

Listpersons=null;

Personperson=null;

XmlPullParserparser=Xml.newPullParser();

InputStreaminStream=PullPersonService.class.getClassLoader().getResourceAsStream("person.xml");

parser.setInput(inStream,"UTF-8");

inteventType=parser.getEventType();//触发第一个事件

while(eventType!

=XmlPullParser.END_DOCUMENT){

switch(eventType){

caseXmlPullParser.START_DOCUMENT:

persons=newArrayList();

break;

caseXmlPullParser.START_TAG:

//开始元素事件

if("person".equals(parser.getName())){

person=newPerson();

person.setId(newInteger(parser.getAttributeValue(0)));

}elseif(person!

=null){

if("name".equals(parser.getName())){

person.setName(parser.nextText());

}elseif("age".equals(parser.getName())){

person.setAge(newShort(parser.nextText()));

}

}

break;

caseXmlPullParser.END_TAG:

//结束元素事件

if("person".equals(parser.getName())){

persons.add(person);

person=null;

}

break;

default:

break;

}

eventType=parser.next();

}

returnpersons;

}

}

以上三种方式任选其一即可。

 

9.根据自己的理解描述下Android数字签名。

 答:

(1)所有的应用程序都必须有数字证书,Android系统不会安装一个没有数字证书的应用程序

(2)Android程序包使用的数字证书可以是自签名的,不需要一个权威的数字证书机构签名认证

(3)如果要正式发布一个Android,必须使用一个合适的私钥生成的数字证书来给程序签名,而不能使用adt插件或者ant工具生成的调试证书来发布。

(4)数字证书都是有有效期的,Android只是在应用程序安装的时候才会检查证书的有效期。

如果程序已经安装在系统中,即使证书过期也不会影响程序的正常功能。

10.已知单链表的头结构head,写一个函数把这个链表逆序。

答:

 如下所示

Node.java

publicclassNode{

privateIntegercount;

privateNodenextNode;

publicNode(){

}

publicNode(intcount){

this.count=newInteger(count);

}

publicIntegergetCount(){

returncount;

}

publicvoidsetCount(Integercount){

this.count=count;

}

publicNodegetNextNode(){

returnnextNode;

}

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 职业教育 > 其它

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1