android部分笔试题.docx
- 文档编号:8253819
- 上传时间:2023-01-30
- 格式:DOCX
- 页数:13
- 大小:20.73KB
android部分笔试题.docx
《android部分笔试题.docx》由会员分享,可在线阅读,更多相关《android部分笔试题.docx(13页珍藏版)》请在冰豆网上搜索。
android部分笔试题
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.xml解析实例:
8.请写一段代码(SAX,DOM,或者pull)来解析XML文档。
答:
下面是要解析的XML文件:
xmlversion="1.0"encoding="UTF-8"?
>
定义一个名为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{
privateList
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;
}
publicList
returnpersons;
}
}
SAXPerson.java
importjava.io.InputStream;
importjava.util.List;
importjavax.xml.parsers.SAXParser;
importjavax.xml.parsers.SAXParserFactory;
importcom.sinber.domain.Person;
publicclassSAXPerson{
publicstaticList
//通过类装载器获取文件
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{
publicstaticList
List
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(List 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(); } publicstaticList List 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; } publicvoidsetNextNod
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- android 部分 笔试