`

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

publicvoid 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;
 }

/**参数:
* ch 整个XML字符串
* start 节点值在整个XML字符串中的索引位置
* length 节点值的长度
*/
 @Override
publicvoid 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);
 }elseif("age".equals(perTag)){
 person.setAge(new Short(data));
 }
 }
 }

 @Override
publicvoid 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;
publicclass SAXPerson{
publicstatic 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;
publicclass DOMPerson {
publicstatic 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()));
 }elseif("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;
publicclass PullPerson {

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

publicstatic 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)));
 }elseif(person!=null){
if("name".equals(parser.getName())){
 person.setName(parser.nextText());
 }elseif("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





publicclass Node {
private Integer count;
private Node nextNode;

public Node(){

 }
public Node(int count){
this.count =new Integer(count);
 }
public Integer getCount() {
return count;
 }
publicvoid setCount(Integer count) {
this.count = count;
 }
public Node getNextNode() {
return nextNode;
 }
publicvoid setNextNode(Node nextNode) {
this.nextNode = nextNode;
 }

}
 


ReverseSingleLink.java
 




publicclass ReverseSingleLink {
publicstatic 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; 
}
publicstaticvoid 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 笔试+答案

    在Android技术领域,笔试是评估求职者技能的重要环节,尤其是对于大公司如华为这样的科技巨头。这份"android 笔试+答案"的压缩包文件包含了四套完整的Android笔试题目及对应的答案,旨在帮助求职者更好地准备面试,...

    Android笔试总结.txt

    根据提供的文件信息,我们可以归纳出以下关键知识点,主要围绕Android开发的基本概念和技术: ### Android系统架构 1. **Android系统架构概述**: - Android操作系统是基于Linux内核的分层架构,它由多层组成,...

    android笔试试题及答案

    这份"android笔试试题及答案"涵盖了Android开发的基础到高级概念,是学习和检验Android编程技能的理想资源。 试题一:Android应用结构 在Android中,一个应用程序的基本单元是应用组件(App Component),包括...

    百度 Android 笔试 面试

    根据给定文件的信息,我们可以总结出以下几个重要的知识点: ### 一、Java中的wait()与sleep()方法的区别 在Java编程语言中,`wait()` 和 `...这对于准备百度Android笔试和面试的人来说,是非常有价值的参考资料。

    Android笔试和面试题汇总

    在Android开发领域,面试和笔试是评估求职者技术能力的重要环节。这份"Android笔试和面试题汇总"资源包含了大量关于Android开发的知识点,旨在帮助应聘者全面了解并准备相关问题。以下是对这些知识点的详细解释: 1...

    android笔试汇总

    "Android笔试汇总"这个主题包含了Android开发者在面试或笔试时可能会遇到的关键知识点,这些知识点通常涵盖语言基础、系统架构、开发工具、API使用等方面。下面将对这些重要知识点进行详细的阐述。 首先,Android的...

    android开发笔试题及答案

    标题“Android开发笔试题及答案”和描述“Android开发笔试题及答案”表明,本文内容主要是关于Android开发领域的技术性笔试题及对应的答案。这些问题涵盖了Android开发的不同知识点,如Java I/O流、编程基本概念、...

    Android基础笔试题

    Android基础笔试题,摘要必须大于100个字节!摘要必须大于100个字节!摘要必须大于100个字节!摘要必须大于100个字节!摘要必须大于100个字节!摘要必须大于100个字节!

    笔试题(Android100选择题).doc

    Android 基础知识点总结 Android 是一种基于 Linux 的开源移动操作系统,主要应用于智能手机和平板电脑等移动设备。Android 系统主要由四大组件组成,即 Activity、Service、BroadcastReceiver 和 ContentProvider...

    HTC android笔试题

    HTC的Android笔试题中涉及了资源目录结构、资源引用方式、国际化和本地化策略,以及一些常用的UI控件如单选框、多选框和下拉列表框的使用。 1. **资源目录结构**: - `res`目录是存放应用资源的地方,通常包含`...

    android-笔试题-答案(面试使用)

    【Android笔试题与面试知识点详解】 在Android开发者领域,面试和笔试是评估候选人技术能力的重要环节。本资料“android-笔试题-答案(面试使用)”包含了一份针对Android开发者的笔试题目集,以及相应的解答,旨在...

    C语言笔试基础总结.txt

    C语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试基础总结.txtC语言笔试...

    建行笔试总结转载的供大家学习

    我也是转载来的供大家学习,希望对大家有帮助

    Android笔试面试指南

    Android笔试面试指南,非常实用,对大家也有帮助,可以看看

    android 面试笔试题(有答案)

    【Android面试笔试题详解】 Android作为全球最大的移动操作系统,其开发者需求旺盛,面试竞争激烈。以下是一些核心的Android知识点,这些题目在许多面试中都可能遇到,它们涵盖了基础概念、编程技巧、性能优化以及...

    android笔试面试题

    在Android开发领域,笔试和面试是评估求职者技术能力的重要环节。这份"android笔试面试题"的压缩包可能包含了各种常见的技术问题,旨在帮助求职者准备这些挑战。下面,我们将详细探讨这些题目可能涵盖的知识点。 一...

    史上最全Android面试笔试大全

    【Android面试笔试题】这份资料集是为准备Android面试的开发者量身打造的,涵盖了从基础到高级的各种知识点,旨在帮助求职者系统性地提升自己的技术能力,顺利走上高薪之路。以下是一些核心的Android面试知识点: 1...

    Android笔试面试题

    ### Android笔试面试题知识点解析 #### 一、基本UI控件和布局文件 在Android开发过程中,掌握基本的用户界面(UI)控件及其布局是非常重要的。以下是对文档中提到的各种控件及其特性的详细介绍。 ##### 1. 文本控件...

Global site tag (gtag.js) - Google Analytics