安卓面试题 转自:http://www.apkbus.com/android-117746-1-1.html

一、方法重载与覆盖的区别?( Overload与Override的区别)
答: 方法的重载属于编译时多态,方法名相同参数列表不一样,返回值必须相同或都没有返回值类型。方法的覆盖属于运行时多态,子类覆盖父类的方法,子类指向父类引用,在调用方法的时候用父类的引用调用。
二、String 和StringBuffer的区别
答: STRING的长度是不可变的,STRINGBUFFER的长度是可变的。若是你对字符串中的内容常常进行操做,特别是内容要修改时,那么使用StringBuffer,若是最后须要String,那么使用StringBuffer的toString()方法。
三、字符串“abcde”经过写一个函数不让调用第三方的字符串,实现一个字符串倒序,好比字符串“abcde” 变成“edcba”
答: String src = "ABCDEF ";
String dst  =  new  StringBuffer(src).reverse().toString();
四、抽象类与接口的区别(abstract与interface的区别)
答:abstract能够修饰抽象方法,而一个类只要有一个抽象方法,就必须用abstract定义该类,即抽象类。
用interface修饰的类,里面的方法都是抽象方法,所以在定义接口的时候,能够直接不加那些修饰,系统会默认的添上去。接口里面的字段都是公有常量,即public static final修饰的字段。
五、集合的实现类与区别?
答:Collection接口,集合结构总的父接口,有两个子接口list和set
   List接口 元素有序可重复.
   实现类有:ArrayList 数组实现轻量级,运行快,线程不安全。JDK1.2 查询快
  Vector   数组实现重量级,运行慢,线程安全。JDK1.0
  LinkedList链表实现 经常使用语堆栈与队列的实现 增删操做快
Set 接口 元素无序不可重复
实现类有:HashSet,底层用hashCode()算法实现,保证元素的无序惟一,自定义对象存进HashSet为了保证元素内容不重复须要覆盖hashCode()与equals()方法。
          SortedSet(不重要) 元素有序(Unicode升序)惟一
  TreeSet要求元素有序,自定义的对象须要实现Comparable接口的 compareTo(object o)方法
Map(接口): 与Collection接口无关,有一个子接口SortedMap特色: 元素是key-value, key
惟一,无序; value可重复
实现类: HashMap 轻量级 线程不安全的,容许key或value为null JDK1.2
        HashTable 重量级 线程安全的 不容许key或value为null   JDK1.0
       Properties是HashTable的子类,主键和值都是字符串
SortedMap:(不重要)
特色: key惟一,有序(Unicode升序)
实现类:TreeMap
六、线程有几种状态,分别是哪些?(调用run()和调用start()的区别)
答:1)、新建状态(New):新建立了一个线程对象。
  2)、就绪状态(Runnable):线程对象建立后,其余线程调用了该对象的start()方法。该状态的线程位于可运行线程池中,变得可运行,等待获取CPU的使用权。
  3)、运行状态(Running):就绪状态的线程获取了CPU,执行run()方法。
  4)、阻塞状态(Blocked):阻塞状态是线程由于某种缘由放弃CPU使用权,暂时中止运行。直到线程进入就绪状态,才有机会转到运行状态。阻塞的状况分三种:
  (一)、等待阻塞:运行的线程执行wait()方法,JVM会把该线程放入等待池中。
  (二)、同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池中。
  (三)、其余阻塞:运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程从新转入就绪状态。
5)、死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。
当调用start方法的时候,该线程就进入就绪状态。等待CPU进行调度执行,此时尚未真正执行线程。
当调用run方法的时候,是已经被CPU进行调度,执行线程的主要任务。
七、线程的实现方式
答:线程的实现有两种方式,一是继承Thread类,二是实现Runnable接口
八、sleep() 与 wait()的区别
答:1.这两个方法来自不一样的类分别是,sleep来自Thread类,和wait来自Object
类。
2.最主要是sleep方法没有释放锁,而wait方法释放了锁,使得其余线程可
以使用同步控制块或者方法。sleep不出让系统资源;wait是进入线程等待池
等待,出让系统资源,其余线程能够占用CPU。通常wait不会加时间限制,
由于若是wait线程的运行资源不够,再出来也没用,要等待其余线程调用
notify/notifyAll唤醒等待池中的全部线程,才会进入就绪队列等待OS分配系
统资源。sleep(milliseconds)能够用时间指定使它自动唤醒过来,若是时间不到
只能调用interrupt()强行打断。
3.wait,notify和notifyAll只能在同步控制方法或者同步控制块里面使用,而
sleep能够在任何地方使用
4. Sleep须要捕获异常,而wait不须要
九、线程中wait,join,sleep,yield, notify,notifyall,synchronized,区别及联系
答:1).sleep()方法
在指定时间内让当前正在执行的线程暂停执行,但不会释放“锁标志”。不推荐使用。sleep()使当前线程进入阻塞状态,在指定时间内不会执行。
2).wait()方法
在其余线程调用对象的notify或notifyAll方法前,致使当前线程等待。线程会释放掉它所占有的“锁标志”,从而使别的线程有机会抢占该锁。
唤醒当前对象锁的等待线程使用notify或notifyAll方法,waite() 和notify()必须在synchronized函数或synchronized block中进行调用。3.yield方法
暂停当前正在执行的线程对象。yield()只是使当前线程从新回到可执行状态,因此执行3)yield()的线程有可能在进入到可执行状态后立刻又被执行。yield()只能使同优先级或更高优先级的线程有执行的机会。
4).join方法
等待该线程终止。等待调用join方法的线程结束,再继续执行。如:t.join();//主要用于等待t线程运行结束,若无此句,main则会执行完毕,致使结果不可预测。
十、Final、finally、finanlize()的区别
答:final?用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不
可继承。
finally是异常处理语句结构的一部分,表示老是执行。
finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,能够覆盖此方法提供垃圾收集时的其余资源回收,例如关闭文件等。
十一、经常使用设计模式及应用场景,用两种方式实现单例模式,要求线程安全?
答:  经常使用设计模式:
    单例模式: Calendar实例的获取
    适配器模式: Adapter为ListView GridView等添加数据
工厂模式: Spring IOC 反转控制
代理模式: Spring AOP 面向切面编程
观察者模式: ContentObserver监听内容改变
(懒汉式)程序执行过程当中须要这个类的对象时再实例化该类的对象
步骤1.定义静态私有对象
2. 构造方法私有化保证在类的外部没法实例化该类的对象
    3. 定义对外开放的静态方法在调用方法是判断对象是否为空,为空再建立对象返回
public class Singleton {
private static Singleton singleton;
// 构造方法私有化,保证在类的外部没法实例化该类的对象
private Singleton() {
}
public static synchronized Singleton getSingletonInstance() {
  if (singleton == null) {
   singleton = new Singleton();
  }
  return singleton;
}
}
(饿汉式)类加载的时候就实例化该类的对象
public class Singleton {
private static Singleton  singleton = new Singleton();
// 构造方法私有化,保证在类的外部没法实例化该类的对象
private Singleton() {
}
public static Singleton getSingletonInstance() {
  return singleton;
}
}
十二、经常使用排序算法,时间复杂度,实现思路
答: 冒泡排序 O(n^2) : 冒泡排序也是最简单最基本的排序方法之一。冒泡排序的思想很简单,就是以此比较相邻的元素大小,将小的前移,大的后移,就像水中的气泡同样,最小的元   素通过几回移动,会最终浮到水面上。
for (int i = 0; i < num.length; i++) {      
// 内循环控制比较后移位      
for (int j = num.length-1; j > i ; j--) {      
                if (num[j-1]>num[j]) {      
                    temp = num[j-1];      
                    num[j-1] = num[j];      
                    num[j] = temp;      
                }      
            }   
快速排序O(n log n)  : 快速排序采用的思想是分治思想。快速排序算法的核心算法是分区操做,即如何调整基准的位置以及调整返回基准的最终位置以便分治递归。
插入排序 O(n^2) :将新来的元素按顺序放入一个已有的有序序列当中。
选择排序 O(n^2) :第i趟简单选择排序是指经过n-i次关键字的比较,从n-i+1个记录中选出关键字最小的记录,并和第i个记录进行交换。共需进行i-1趟比较,直到全部记录排序完成为止。
1三、android系统架构?
答:1)应用程序层      java语言    应用程序开发
2)应用程序框架层  java语言    OS定制  framework层开发
3)系统运行库层    C C++ 实现   so库
4)Linux内核层
1四、Activity生命周期?保存activity的一些信息在哪一个生命周期方法中?
答:共有七个周期函数:
void onCreate(Bundle savedInstanceState) 第一次建立时调用
void onStart()   被用户可见时调用
void onRestart()  当Activity处于stop状态又被从新启动时调用
void onResume() 当得到焦点便可与用户交互时调用
void onPause()  当失去焦点时调用
void onStop()   当不可见时调用
void onDestroy()  当销毁时调用
1五、Activity的 onSaveInstanceState() 和 onRestoreInstanceState()
答: Activity的 onSaveInstanceState() 和 onRestoreInstanceState()并非生命周期方法,它们不一样于 onCreate()、onPause()等生命周期方法,它们并不必定会被触发。当应用遇到意外状况(如:内存不足、用户直接按Home键)由系统销毁一个Activity时,onSaveInstanceState() 会被调用。可是当用户主动去销毁一个Activity时,例如在应用中按返回键,onSaveInstanceState()就不会被调用。由于在这种状况下,用户的行为决定了不须要保存Activity的状态。一般onSaveInstanceState()只适合用于保存一些临时性的状态,而onPause()适合用于数据的持久化保存。
另外,当屏幕的方向发生了改变, Activity会被摧毁而且被从新建立,若是你想在Activity被摧毁前缓存一些数据,而且在Activity被从新建立后恢复缓存的数据。能够重写Activity的 onSaveInstanceState() 和 onRestoreInstanceState()方法。
1六、Android的四大组件是什么?它们的做用是什么?
答:Android有四大组件:Activity、Service、Broadcast Receiver、Content Provider。
Activity :应用程序中,一个Activity一般就是一个单独的屏幕,它上面能够显示一些控件也能够监听并处理用户的事件作出响应。Activity之间经过Intent进行通讯。
Service 服务:一个Service 是一段长生命周期的,没有用户界面的程序,能够用来开发如监控类程序。
BroadcastReceive广播接收器:你的应用可使用它对外部事件进行过滤只对感兴趣的外部事件(如当电话呼入时,或者数据网络可用时)进行接收并作出响应。广播接收器没有用户界面。然而,它们能够启动一个activity或serice 来响应它们收到的信息。
Content Provider内容提供者 :主要用于多个应用间数据共享。这些数据能够存储在文件系统中或SQLite数据库。
1七、广播如何调用,有什么方式,各自的区别?
答:程序中发送广播经过sendBroadcastReceiver()实现
接收广播经过定义一个类继承BroadcastReceiver并重写onReceive()方法实现
注册广播有两种方式:
第一种静态方式:在清单文件中经过<receive>标签声明
第二种代码动态方式:
IntentFilter filter =  new IntentFilter("android.provider.Telephony.SMS_RECEIVED");
IncomingSMSReceiver receiver = new IncomgSMSReceiver();
registerReceiver(receiver.filter);
1)第一种不是常驻型广播,也就是说广播跟随activity的生命周期。注意: 在activity结束前,移除广播接收器。
2)第二种是常驻型,也就是说当应用程序关闭后,若是有信息广播来,程序也会被系统调用自动运行。
1八、Android中asset文件夹和raw文件夹区别?
答:res/raw和assets的相同点:
二者目录下的文件在打包后会原封不动的保存在apk包中,不会被编译成二进制。
res/raw和assets的不一样点:
1)res/raw中的文件会被映射到R.java文件中,访问的时候直接使用资源ID即   R.raw.filename;assets文件夹下的文件不会被映射到R.java中,访问的时候须要AssetManager类。
2)res/raw不能够有目录结构,而assets则能够有目录结构,也就是assets目录下能够再创建文件夹
3)读取文件资源举例:
读取res/raw下的文件资源,经过如下方式获取输入流来进行写操做
InputStream is = getResources().openRawResource(R.raw.filename);
读取assets下的文件资源,经过如下方式获取输入流来进行写操做
AssetManager am = null;
am = getAssets();
InputStream is = am.open("filename");
1九、Android中的五种存储方式及其应用场景
答:1)SharedPreferences   
存储路径:(data/data/packagename/shares_prefs), 轻量级存储,以键值对的形式存储在xml中,通常用来保存应用中的设置属性
    2)文件存储             ;opSD卡存储多媒体文件, 文件缓存
    3) Sqlite数据库        存储路径:(data/data/packagename/databases), 一种嵌入式数据库,支持sql语言,存储大量结构性数据
    4)ContentProvider  进程(应用程序)间数据共享,数据源能够是sqlite,也能够是xml,相关类: ContentResolver(内容解析器), ContentObserver(数据                        观察者)
    5) 网络存储    天气数据的xml,json格式等等,经过HttpUrlConnection,HttpClient,或者SOAP协议获取数据
20、什么是ANR 如何避免它?(Android线程间的通讯方式? )
答:ANR:Application Not Responding(应用程序无响应).当出现下列状况时,Android就会显示ANR对话框了:   对输入事件(如按键、触摸屏事件)的响应超过5秒 意向接受器(intentReceiver)超过10秒钟仍未执行完毕Android应用程序彻底运行在一个独立的线程中(例如main)。这就意味着,任何在主线程中运行的,须要消耗大量时间的操做都会引起ANR。
解决方案有两种:
1. AsyncTask异步任务中,doInBackground()和onPostExecute(Result)两个方法很是重要
doInBackground() 这个方法运行在后台线程中,主要负责执行那些很耗时的操做,如移动护理系统中的网络链接、解析XML等操做。该方法必须重载。
onPostExecute(Result) 这个方法也运行于UI线程,在doInBackground(Params…)方法执行后调用,该方法用于处理后台任务执行后返回的结果。
2.  子thread + handler
2一、Handler的运行机制(运行原理)(Handler,Looper,MessageQueue,Message之间的关系)
一个Handler容许你发送和处理Message和Runable对象,每一个线程都有本身的Looper,每一个Looper中封装着MessageQueue。Looper负责不断的从本身的消息队列里取出队头的任务或消息执行。每一个handler也和线程关联,Handler负责把Message和Runable对象传递给MessageQueue(用到post ,sendMessage等方法),并且在这些对象离开MessageQueue时,Handler负责执行他们(用到handleMessage方法)。
其中Message类就是定义了一个信息,这个信息中包含一个描述符和任意的数据对象,这个信息被用来传递给Handler.Message对象提供额外的两个int域和一个Object域。
2二、listview优化策略?
答:1)、对convetView进行判空,是当convertView不为空的时候直接从新使用convertView
从而减小了不少没必要要的View的建立
2)定义一个ViewHolder,将convetView的tag设置为ViewHolder,不为空时从新使用便可
3)、当ListView加载数据量较大时能够采用分页加载和图片异步加载
2三、ListView分页加载实现思路?
实现OnScrollListener 接口重写onScrollStateChanged 和onScroll方法,使用onscroll方法实现”滑动“后处理检查是否还有新的记录,若是有,调用 addFooterView,添加记录到adapter, adapter调用 notifyDataSetChanged 更新数据;若是没有记录了,把自定义的mFooterView去掉。使用onScrollStateChanged能够检测是否滚到最后一行且中止滚动而后执行加载   
2四、ListView图片异步加载实现思路?
1.先从内存缓存中获取图片显示(内存缓冲)
2.获取不到的话从SD卡里获取(SD卡缓冲,,从SD卡获取图片是放在子线程里执行的,不然快速滑屏的话会不够流畅)
3.都获取不到的话从网络下载图片并保存到SD卡同时加入内存并显示(视状况看是否要显示)
2五、Intent的原理,做用,能够传递哪些类型的参数?
答:intent是链接Activity, Service, BroadcastReceiver, ContentProvider四大组件的信使,,能够传递八种基本数据类型以及string, Bundle类型,以及实现了Serializable或者Parcelable的类型。
Intent能够划分红显式意图和隐式意图。
显式意图:调用Intent.setComponent()或Intent.setClass()方法明确指定了组件名的Intent为显式意图,显式意图明确指定了Intent应该传递给哪一个组件。
隐式意图:没有明确指定组件名的Intent为隐式意图。 Android系统会根据隐式意图中设置的动做(action)、类别(category)、数据(URI和数据类型)找到最合适的组件来处理这个意图。
2六、如何实现屏幕分辨率的自适应?
答: 最好能够经过权重(layout_weight)的方式来分配每一个组件的大小,也能够经过具体的像素(dip)来肯定大小。
尽可能使用Relativelayout  。
已知应用支持平台设备的分辨率,能够提供多个layout_320*480  ...
drawable-hdpi,drawable-mdpi,drawable-ldpi分别表明分辨率为480*800,360*480,240*360, 放置图片大小相差1.5倍
最后还须要在AndroidManifest.xml里添加下面一段,没有这一段自适应就不能实现:
<supports-screens
android:largeScreens="true"
android:normalScreens="true"
  android:anyDensity = "true"/>
在</application>标签和</manifest> 标签之间添加上面那段代码。便可。
备注:三者的解析度不同,就像你把电脑的分辨率调低,图片会变大同样,反之分辨率高,图片缩小
还能够经过.9.png实现图片的自适应
2七、简述Android中的IPC机制
IPC(Inter-Process Communication,进程间通讯),aidl是 Android Interface definition language的缩写,它是一种android内部进程通讯接口的描述语言,经过它咱们能够定义进程间的通讯接口.编译器能够经过扩展名为aidl的文件生成一段代码,经过预先定义的接口达到两个进程内部通讯进程的目的.
BroadcastReceiver也能够实现进程间通讯
ContentProvider 提供进程间数据共享
2八、Android程序入口如何判断?
action节点中的android.intent.action.MAIN代表它所在的Activity是整个应用程序的入口点
2九、android哪几种方式访问网络?
HttpURLConnection
HttpClient方式(HttpGet和HttpPost类)
30、说说HttpClient的通讯过程
1.生成请求对象(HttpGet get,HttpPost post)
2.生成客户端对象 HttpClient client
3.执行请求接收相应 HttpResponse response = client.execute(post)
                     HttpEntity entity = response.getEntity()
4.获得数据流
InputStream inputStream = entity.getContent();
5.最后关闭过时链接
3一、移动互联数据交互格式有哪些及其区别?(Json与xml的区别?)
移动互联数据交互格式有XML和JSON
1.JSON和XML的数据可读性基本相同
2.JSON和XML一样拥有丰富的解析手段
3.JSON相对于XML来说,数据的体积小
4.JSON与JavaScript的交互更加方便
5.JSON对数据的描述性比XML较差
6.JSON的速度要远远快于XML
3二、XML解析有哪几种?各自优缺点,官方推荐使用哪一种?
基本的解析方式有三种: DOM,SAX,Pull
1.dom解析解析器读入整个文档,而后构建一个驻留内存的树结构,而后代码就可使用 DOM 接口来操做这个树结构的优势是对文档增删改查比较方便,缺点占用内存比较大。
2.sax解析基于事件驱动型,优势占用内存少,解析速度快,缺点是只适合作文档的读取,不适合作文档的增删改查。
3.pull解析一样基于事件驱动型,android 官方API提供,可随时终止
3三、百度地图核心类,及实现的功能?
BMapManager:地图引擎管理类,负责初始化,开启地图API,终止百度地图API等工做
MKSearch:搜索服务.用于位置检索、周边检索、范围检索、公交检索、驾乘检索、步行检索
MKSearchListener搜索结果通知接口。该接口返回poi搜索,公交搜索,驾乘路线,步行路线结果
MapView:显示地图的View
MyLocationOverlay:一个负责显示用户当前位置的Overlay。
Overlay:Overlay是一个基类,它表示能够显示在地图上方的覆盖物。
3四、GC内存泄露在什么状况下回出现?怎么解决?
(一) 查询数据库没有关闭游标
(二) 构造Adapter时,没有使用缓存的 convertView
(三) Bitmap对象不在使用时调用recycle()释放内存
(四) 不用的对象没有及时释放对象的引用
3五、android内存的优化
答:android内存泄露容易致使内存溢出,又称为OOM。
Android内存优化策略:
1)在循环内尽可能不要使用局部变量
2)不用的对象即时释放,即指向NULL
3)数据库的cursor即时关闭。
4)构造adapter时使用缓存contentview
5)调用registerReceiver()后在对应的生命周期方法中调用unregisterReceiver()
6)即时关闭InputStream/OutputStream。
7)android系统给图片分配的内存只有8M, 图片尽可能使用软引用, 较大图片可经过BitmapFactory缩放后再使用,并及时recycle
8)尽可能避免static成员变量引用资源耗费过多的实例。
3六、加载大图片的时候如何防止内存溢出
答: android系统给图片分配的内存只有8M,当加载大量图片时每每会出现OOM。
Android加载大量图片内存溢出解决方案:
1)尽可能不要使用setImageBitmap或setImageResource或BitmapFactory.decodeResource来设置一张大图,由于这些函数在完成decode后,最终都是经过java层的createBitmap来完成的,须要消耗更多内存,能够经过BitmapFactory.decodeStream方法,建立出一个bitmap,再将其设为ImageView的 source  
2)使用BitmapFactory.Options对图片进行压缩
InputStream is = this.getResources().openRawResource(R.drawable.pic1);
     BitmapFactory.Options options=new BitmapFactory.Options();
     options.inJustDecodeBounds = false;
     options.inSampleSize = 10;   //width,hight设为原来的十分一
     Bitmap btp =BitmapFactory.decodeStream(is,null,options);
3)运用Java软引用,进行图片缓存,将须要常常加载的图片放进缓存里,避免反复加载
及时销毁再也不使用的Bitmap对象
   if(!bmp.isRecycle() ){
         bmp.recycle()   //回收图片所占的内存
         system.gc()  //提醒系统及时回收
   }
3七、Android缓存机制
答: 客户端缓存机制是android应用开发中很是重要的一项工做,使用缓存机制不只仅能够为用户节省3G流量,同时在用户体验方面也是很是好的选择,好比有些新闻客户端支持离线模式,也是经过缓存机制实现的.缓存机制分为两部分,一部分是文字缓存,另外一部分是多媒体文件缓存.
文字缓存有两种实现:
1)能够将与服务器交互获得的json数据或者xml数据存入sd卡中,并在数据库添加该数据的记录.添加数据库记录时,提供两个关键字段,一个是请求的URL,另外一个则是本地保存后的文件地址,每次加载数据以前都会根据URL在数据库中检索
2)将JSON数据解析后装入List<Map>对象中,而后遍历List,将数据通通写入相应的数据库表结构中,之后每次向服务器发起请求以前能够先在数据库中检索,若是有直接返回.
多媒体文件缓存:主要指图片缓存
图片的缓存能够根据当前日期,时间为名字缓存到SD卡中的指定图片缓存目录,同时数据库中作相应记录,记录办法能够采用两个关键字段控制,一个字段是该图片的URL地址,另外一个字段是该图片的本机地址.取图片时根据URL在数据中检索,若是没有则链接服务器下载,下载以后再服务器中做出相应记录
缓存文件删除策略:
1. 每个模块在每次客户端自动或者用户手动更新的时候删除相应模块的缓存文件,并从新下载新的缓存文件.
2. 在设置界面中提供删除缓存的功能,点击后删除本机全部缓存.
3八、如何实现消息推送,有哪些方式,各自优缺点,最常使用哪一种?
答:实现消息推送的方式有五种,分别是轮询,SMS,C2DM,MQTT,XMPP最常使用的是XMPP, 咱们作项目时采用的是XMPP协议
1.XMPP协议,它是一种基于XML的传递协议,具备很强的灵活性和可扩展性。它的特色是将复杂性从客户端转移到了服务器端。GTalk、QQ、IM等都用这个协议。
2.轮询:客户端定时去服务端取或者保持一个长Socket,从本质讲这个不叫推送,    而是去服务端拽数据。可是实现简单,主要缺点:耗电,浪费用户流量等
3.Google的C2DM,具体不细说,缺点,服务器在国外,不是很稳定。
4.经过短信方式, 可是很难找到免费短信平台
5. MQTT协议, IBM提供的一种推送服务,不太灵活
3九、MVC在Android中的应用
答: Android中界面部分也采用了当前比较流行的MVC框架,在Android中:
  1) 视图层(View):通常采用XML文件进行界面的描述,使用的时候能够很是方便的引入。也可使用JavaScript+HTML等的方式做为View层,经过WebView组件加载,同时能够实现Java和JavaScript之间的通讯。     
  2) 控制层(Controller):这句话也就暗含了不要在Acitivity中写代码,要经过Activity交割Model业务逻辑层处理,这样作的另一个缘由是Android中的Acitivity的响应时间是5s,若是耗时的操做放在这里,Android的控制层的重任一般落在了众多的Acitvity的肩上,程序就很容易被回收掉。
3) 模型层(Model):对数据库的操做、对网络等的操做都应该在Model里面处理,固然对业务计算等操做也是必须放在的该层的。
      在Android SDK中的数据绑定,也都是采用了与MVC框架相似的方法来显示数据。在控制层上将数据按照视图模型的要求(也就是Android SDK中的Adapter)封装就能够直接在视图模型上显示了,从而实现了数据绑定。好比显示Cursor中全部数据的ListActivity,其视图层就是一个ListView,将数据封装为ListAdapter,并传递给ListView,数据就在ListView中显示。
40、Android自定义组件实现思路
答: Android自定义组件有三种实现思路:
1) 继承某个现有组件,在其基础上添加额外功能,如继承Gallery实现CoverFlow效果
2) 继承某个Layout,实现复合组件自定义,如TextView和EditText组合实现登陆注册组件
3) 继承View,实现onDraw()方法,实现本身绘制组件,如翻页效果组件
4一、版本更新的实现思路
答:在服务器相应URL上有版本文件, 客户端同时存储该应用当前版本号  (SharedPreferences/Sqlite), 每次打开应用,去检测服务器版本号与本地版本号是否一致,若是不一 致,则自定义对话框提示是否下载更新
4二、播放视频有哪些实现方式?
答:1.使用系统自带的播放器来播放,指定Action为ACTION_VIEW,Data为Uri,Type为其MIME类型。
//调用系统自带的播放器     
          Intent intent = new Intent(Intent.ACTION_VIEW);   
          intent.setDataAndType(uri, "video/mp4");   
          startActivity(intent);
2. 使用VideoView组件来播放, 能够结合MediaController来实现播控, 只是不能随意更改视频的大小及位置。
3. 使用MediaPlayer和SurfaceView来实现,这种方式很灵活,能够自定义视频播放的大小和位置。
4三、NDK开发流程?(JNI运行原理)
答: NDK应用的开发流程(在应用中定义本地接口(native), 编译成.h头文件,交由C程序员实现,将.c实现经过NDK编译成.so动态连接库,导入项目中libs/armeabi,代码中调用该本地接口)
应用场景: 音频,视频解码,拍摄车牌号,识别车牌号
4四、如何实现一键退出?
答:定义一个类继承Application,定义一个集合存放全部的activity,
定义一个添加的方法,再写一个退出的方法,使用for循环所有调用finish方法,然
后在每一个Activity的onCreate方法中调用自定义类里的添加方法,而后在须要使用一
键退出的地方调用类中的退出方法便可。
4五、AndroidManifest.xml清单文件<Activity>标签中属性android:excludeFromRecents="true" android:screenOrientation="portrait"     android:configChanges="orientation|locale"的含义
答: android:excludeFromRecents表示是否可被显示在最近打开的activity列表里,true表示否,false表示是
android:screenOrientation表示activity显示的模式, 通常用来设置activity横屏显示(horizontal)或竖屏显示(portrait)
android:configChanges=[oneormoreof:"mcc""mnc""locale""touchscreen""keyboard""keyboardHidden""navigation""orientation""fontScale"]
是当所指定属性(Configuration Changes)发生改变时,通知程序调用 onConfigurationChanged()函数,好比orientation屏幕方向发生改变,locale语言环境发生改变时
4六、如何将一个Activity设置成窗口的样式
答:在清单文件AndroidManifest.xml中相应的<activity>标签内设置属性android:theme=”@android:style/Theme.Dialog”
4七、谈谈UI中, Padding和Margin有什么区别,gravity与layout_gravity的区别
答:Padding 用来指定组件内的内容距离组件边界的距离;
    Margin用来指定控件与控件之间的距离
Gravity用来指定组件内的内容相对于组件自己的位置
Layout_gravity用来指定组件相对于其父组件的位置
4八、哪一个组件能够实现手风琴效果,用来实现设置界面的类,实现抽屉效果, 悬浮窗口?
答:实现手风琴效果(ExpandableListView)
设置界面的类(preferenceActivity)保存到sharedpreference中
抽屉效果(slidingDrawer)组件
    悬浮窗口: PopWindow,能够实现相似Dialog和菜单的效果
4九、Android SDK 3.0(HoneyComb)及4.0(Ice Cream)新特性
答:新版SDK发布的同时也发布了一个扩展包android-support-v4,把部分特性单独的抽出来,使低版本的SDK也可使用这些特性,主要支持如下特性:
Fragment: 3.0引入,碎片管理,能够局部刷新UI,它设计的功能和Activity同样强大,包括生命周期、导航等,Fragment的每次导航均可以记录下来用于返回。
ViewPager: 提供了多界面切换的新效果
GridLayout: 4.0引入, 网格布局, android第六大布局
Loader: 装载器从android3.0开始引进。它使得在activity或fragment中异步加载数据变得简单
50、android客户端如何实现自动登陆
答: 经过SharedPreferences存储用户名,密码,当存储不为空时实现自动登陆功能java

相关文章
相关标签/搜索