最新Android面试题整理
http://www.drovik.com/ 2013-5-10 22:34:10 来源:www.drovik.com 点击:
**面试题
Java基础
1.说出sleet,wait,notify的区别
盘古搜索面试总结
算法题
2.求一个数组的最大连续子序列和,比如:-10,3,5,2,-3,6,7
最笨的方法就是穷举法,用三层for循环
3.求一个数组中出现次数最多且值最大的数
android的基础题
1.service的生命周期
2.Intent用途,了解多少?IntentService知道么?
3.自定义控件
4.xmpp协议的理解
5.广播创建方式有几种?有什么区别?
6.多线程有几种实现方式?
继承Thread, 实现Runnable接口, AsynTask
------------------------------------------------------------
一、listview如何优化(这个很重要,多次被问到)
1.分页加载
2.convertView缓存
3.viewHolder
4.scrollListener,记住滑动的状态
二、常用排序算法,各种算法的复杂度,用Java实现一种排序算法。
四、单链表的反转、合并、排序
五、二分查找法
六、Intent Flag常用的记住几个
七、AIDL怎么用?全称是什么?
八、taskAffinity 亲和性
这个一般人应该都不熟悉,了解一下,面试中可能被问到,几率不大。
--------------------------------------------------------------
百度各种面试总结
1.Listview item缓存如何实现
convertView
2.很多view如何缓存
3.图片上传
4.图片过大如何处理?压缩后图片有多大?
分辨率压缩、质量压缩
5.OOM怎么办?
6.图片的缓存机制,如何做到高效和稳定?
7.自定义view怎么做能提高效率? 自定义view如何做图片缓存?自定义view如何判断单击和双击?自定义view 的 onDraw方法主要做什么?
避免重复调用measure 和 layout
8.是否看过view的源码
9.动画的机制及其底层实现?
10.二叉树、链表
11.平时看什么书?去哪些论坛看?
12.问项目底层实现
13.Linux文件系统实现,如何实现文件的隐藏?
=================================================================================================================
android 应用之间有几种共享数据的方法
android 哪些操作会导致内存泄露 如何排查
.9.png 和 png 的区别
sqlite 使用注意事项
Listview 中 getview中 convertview 的工作原理
service 有什么特征,在哪种情况下会用到service
面试
面试的时候会问你关于简历上的项目,会问得比较细,问你几个人做的,做了多长时间,画出原理图
intent 如何开启activity的?
manifest 的作用
内存过低时,是用什么策略杀死进程@?
1.int a = 1;
int result = a+++3<<2;
int result = a+++3<<2;
2.int a = 2;
int result = (a++ > 2)?(++a):(a+=3);
int result = (a++ > 2)?(++a):(a+=3);
3.int a = 1234567;
int b = 0x06;
int result = a&b;
int b = 0x06;
int result = a&b;
4.Integer a = 34556;
Integer b = 34556;
boolean result = a==b;
Integer b = 34556;
boolean result = a==b;
5.String func(string s ){
return s.length() > 0 ? func(s.subString(1))+ s.charAt(0):"";
}
String result = func("Tencent");
return s.length() > 0 ? func(s.subString(1))+ s.charAt(0):"";
}
String result = func("Tencent");
6.byte result = (byte) oxffeffefe;
7.int result = [(oxfe2baf&oxf)|oxff] >> 2/(4<<1);
8.判断两个String的交集
比如 A = "Marginle",B = Valaienie", 交集为aie,写个算法。
比如 A = "Marginle",B = Valaienie", 交集为aie,写个算法。
9.什么是状态机?项目中什么时候用到状态机,举例说明。
10.写出两种单例模式
Android基础
1.Activity和BroadCast Receiver的生命周期
1.Activity和BroadCast Receiver的生命周期
2.写出几种service和Activity的交互方式
3.UI线程和非UI线程的交互方式,写出几种各自的耗时。
4.requestLayout, invalidate和postInvalidate的异同
5.写出三种常用layout布局并进行解释
6.http怎么加入超时和代理
7.view的绘制过程,讲讲draw/onDraw和drawChild这个可以口述。
8.以下是Android sdk的英文文档请细读。
9.100盏灯,全部关闭,第一人全部打开(亮),第二个人隔一个按开关,第三个人隔2个按开关,以此类推,第100人路过时有几盏灯亮着?(写出结果就行)
Java基础
1.说出sleet,wait,notify的区别
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
百度面试题
2013-5-2号补充:
1.View和ViewGroup的关系
2.如何定位和解决Andorid的内存溢出问题
3.一个有N个元素的一维数组(A[0],A[1], ..., A[n-1]),设计一个算法求解该数组最大子数组。(要求时间复杂度是O(n))
4.用Java代码实现判断一个字符串中是否包含另一个字符串,不要用jdk中String的indexOf方法。
5.用Java实现一个Singleton.
6.简述Observer设计模式,并画出Observer模式的典型结构类图
7.& 和&&的区别
8.什么是dpi,ps,sp?适配是如何做的,为什么?
9.用最有效率的方法算出2乘以8等于几?
10.静态成员类、非静态成员类有什么区别?什么是匿名内部类?
11.Handler机制的原理,内部是如何实现的,消息队列的实现机制?
12.什么是ANR,如何定位和避免?
13.APK之间互相传递数据
14.简述Android的启动过程
15.如何加载ndk库?如何在jni中注册native函数,有几种注册方法?
16.如何收集软件崩溃信息?
17.简述软件编译流程和发布流程
18.是否编译过android源码和linux内核源码
19.写一个归并排序数组
20.自定义控件相关
21.缓存实现
22.线程同步(生产者 消费者)
23.符号匹配(栈)
24.还问了下拉刷新和分页加载的实现机制
-------------------------------------------------------
2.如何定位和解决Andorid的内存溢出问题
3.一个有N个元素的一维数组(A[0],A[1], ..., A[n-1]),设计一个算法求解该数组最大子数组。(要求时间复杂度是O(n))
4.用Java代码实现判断一个字符串中是否包含另一个字符串,不要用jdk中String的indexOf方法。
5.用Java实现一个Singleton.
6.简述Observer设计模式,并画出Observer模式的典型结构类图
7.& 和&&的区别
8.什么是dpi,ps,sp?适配是如何做的,为什么?
9.用最有效率的方法算出2乘以8等于几?
10.静态成员类、非静态成员类有什么区别?什么是匿名内部类?
11.Handler机制的原理,内部是如何实现的,消息队列的实现机制?
12.什么是ANR,如何定位和避免?
13.APK之间互相传递数据
14.简述Android的启动过程
15.如何加载ndk库?如何在jni中注册native函数,有几种注册方法?
16.如何收集软件崩溃信息?
17.简述软件编译流程和发布流程
18.是否编译过android源码和linux内核源码
19.写一个归并排序数组
20.自定义控件相关
21.缓存实现
22.线程同步(生产者 消费者)
23.符号匹配(栈)
24.还问了下拉刷新和分页加载的实现机制
-------------------------------------------------------
盘古搜索面试总结
算法题
2.求一个数组的最大连续子序列和,比如:-10,3,5,2,-3,6,7
最笨的方法就是穷举法,用三层for循环
3.求一个数组中出现次数最多且值最大的数
android的基础题
1.service的生命周期
2.Intent用途,了解多少?IntentService知道么?
3.自定义控件
4.xmpp协议的理解
5.广播创建方式有几种?有什么区别?
6.多线程有几种实现方式?
继承Thread, 实现Runnable接口, AsynTask
------------------------------------------------------------
一、listview如何优化(这个很重要,多次被问到)
1.分页加载
2.convertView缓存
3.viewHolder
4.scrollListener,记住滑动的状态
二、常用排序算法,各种算法的复杂度,用Java实现一种排序算法。
四、单链表的反转、合并、排序
五、二分查找法
六、Intent Flag常用的记住几个
七、AIDL怎么用?全称是什么?
八、taskAffinity 亲和性
这个一般人应该都不熟悉,了解一下,面试中可能被问到,几率不大。
--------------------------------------------------------------
百度各种面试总结
1.Listview item缓存如何实现
convertView
2.很多view如何缓存
3.图片上传
4.图片过大如何处理?压缩后图片有多大?
分辨率压缩、质量压缩
5.OOM怎么办?
6.图片的缓存机制,如何做到高效和稳定?
7.自定义view怎么做能提高效率? 自定义view如何做图片缓存?自定义view如何判断单击和双击?自定义view 的 onDraw方法主要做什么?
避免重复调用measure 和 layout
8.是否看过view的源码
9.动画的机制及其底层实现?
10.二叉树、链表
11.平时看什么书?去哪些论坛看?
12.问项目底层实现
13.Linux文件系统实现,如何实现文件的隐藏?
---------------------------------------------------------------------------------------------------------
面试算法题总结
1.有一个整数数组,有负数和整数,用一个方法把正负数分开,要求空间复杂度是O(1),时间复杂度是:O(N)(百度移动平台部)
2.有一个数列,奇数个,其中有3个是单个的, 其它都是成对的,怎么找出其中任意一个单个的数(小米一面)
3.在一个数组中,找出出现次数最多且数值最大的一个数并输出
4.用最快的方式将两个数组合并到一个数组中?时间复杂度
面试算法题总结
1.有一个整数数组,有负数和整数,用一个方法把正负数分开,要求空间复杂度是O(1),时间复杂度是:O(N)(百度移动平台部)
2.有一个数列,奇数个,其中有3个是单个的, 其它都是成对的,怎么找出其中任意一个单个的数(小米一面)
3.在一个数组中,找出出现次数最多且数值最大的一个数并输出
4.用最快的方式将两个数组合并到一个数组中?时间复杂度
============================================================================================
2013-4-10补充:
问题:怎样的类可以作为HashMap的键?
答:这个问题是搜狗2012年的笔试题,我开始还真是没想太明白。刚才看到HashMap的时候才发现原来是这么回事。
当需要往ArrayList,HashMap中放东西时,像int,double这种内建类型是放不进去的,因为容器都是装object的,这就需要这些内建类型的外覆类了。比如:int对应的Integer,double对应的Double。
答:这个问题是搜狗2012年的笔试题,我开始还真是没想太明白。刚才看到HashMap的时候才发现原来是这么回事。
当需要往ArrayList,HashMap中放东西时,像int,double这种内建类型是放不进去的,因为容器都是装object的,这就需要这些内建类型的外覆类了。比如:int对应的Integer,double对应的Double。
同样是搜狗的笔试题:适合频繁插入和查找的数据结构
答:频繁插入,链表效率高,频繁查找数组效率高,那么综合一下,我个人觉得是哈希表,或者说HashMap等使用hash算法的数据结构。
答:频繁插入,链表效率高,频繁查找数组效率高,那么综合一下,我个人觉得是哈希表,或者说HashMap等使用hash算法的数据结构。
1、对于简历上所写的每个问题,面试官感兴趣的会对我提问,并分析里边遇到的问题以及得到的经验。面试过程描述以前做过的项目。项目中你认为的难点是什么。
2、对于网络交互这块儿需要注意什么问题
2、对于网络交互这块儿需要注意什么问题
3、android是一个什么样的系统。Jni调用机制是什么。用uml画一个在你的项目中使用的设计模式。
面试中常问的非技术类问题:
1.简单介绍一下你自己。
2.对自己做个评价,优点、缺点。
3.自己做过的项目,详细介绍一下。
4.实习经历,在实习过程中遇到哪些问题,如何解决的?
5.你对公司有什么问题要问吗(对公司有什么要了解的)?
技术类的问题主要就看对技术的掌握程度和自己的综合能力了。
百度移动终端研发工程师笔试题,题量不大,2个小时,有点难度。
1.写一个字符串逆序的程序,时间复杂度和空间复杂度最低,效率越高越好。
2.实质:二叉树的层序遍历,每层的结点用单链表输出。
3.1-N(N最大32000,且未知),内存只有4K,找出其中的重复数
4.编程题,比较复杂,是个系统设计题,与《编程之美》中3.2,电话号码对应英语单词类似。
百度软件开发工程师一面问题:
1.有101个数,为[1,100]之间的数,其中一个数是重复的,如何寻找这个重复的数,其时间复杂度和空间复杂度是多少?
2.Java中抽象类与接口的区别。
3.进程与线程之间的联系与区别。(多家公司都在问,好好研究一下)
4.谈谈对设计模式的认识与理解,简单介绍一下你所知道的设计模式。(多家公司都问,Android方向面试必考的)
5.线程、多线程相关(必问)
6.Linux常用的命令,shell编程,grep命令的使用。
7.海量数据查找或者排序,有资源限制要求。(常考的)
建议:简历中对自己的专业技能要实事求是的写,突出自己的重点,不宜托大,面试官面试时提问的依据就是简历上的内容。百度的工作环境很好,做技术的员工给人的感觉就是虽然人家的技术水平很高,但是都比较谦逊。百度确实是一个不错的互联网公司。
Sina无线客户端开发工程师面试
笔试的题目和7月22日实习生的题目差不多。面试主要问了:
1.二叉树的一些基础知识。
2.Java多线程,对stop()方法的认识,如何安全的终止一个线程。
3.设计模式相关的问题
4.谈谈你对面向对象编程中继承的认识
5.排序算法
网易2012校招无线客户端开发笔试,题目不太难,比较基础。
1.面向对象编程中多态的概念,用伪代码展示出来。
2.斐波那契数列编程,效率越高越好(详见《编程之美》2.9)
3.60W长度为32的字符串一次性读入内存中,大约占用多少内存空间?
4.一个X向量n,如何求其内部的最大距离。
5.在浏览器中输入http://www.163.com,从输入到页面在浏览器中显示出来,期间发生了哪些过程,越详细越好。
6.简单介绍一下Android系统中的Activity,Service, Intent, ContentProvider组件。
7.编程解析一段josn格式内容,并在界面上显示出来。
8.英文阅读,考察英语能力。
9.网络应用分析,发挥自己的主观能动性和积累。
搜狗2012校招笔试
搜狗的题目出的很全,所有职位的题目都在一份卷子上,涉及到数据结构、网络、操作系统、算法、软件工程等多方面,根据自己所投递的职位,有针对性的选择要答的题目即可。
金山2012校园招聘笔试
为了保险,做了运维的题目,难度不大,主要是网络和Linux操作系统方面的,稍微准备一下即可。答题的时候自我感觉良好,结果没收到面试通知,被鄙视了,o(╯□╰)o
Android开发工程师面试中经常会问到的问题
1.Activity的生命周期(最基本的)。
2.Android基本框架结构。
3.Android终止一个进程的方法,如何彻底终止一个程序。
4.如何改写程序,改变android手机中返回键的功能(西安TCL研究院技术面试)。
一般来说,大公司的校园招聘中首先看的还是基础,有工作或者实习经验的会重点考虑,多问一些在实习中的项目细节,同时会问一些算法,建议认真研读《编程之美》《编程珠玑》之类的书籍。首先要做好充足的准备,打好基础,其次还要看一些算法、设计的内容,一面以后的技术面问的题目都有一定的挑战性。如果有实习或者项目经历,可以大大增加校招中简历筛选通过的机率。对于互联网公司,特别喜欢海量数据的排序、搜索,网上类似的资源很多,可以看看。技术更新永无止境,要时刻保持清醒的头脑,不断学习,充实自己,才能在竞争中不被淘汰,祝大家好运,找到心仪的工作。
=================================================================================================================
1.程序之间亲和性的理解
eoe的一个朋友的回答,要不我还真想不到是什么。
是问affinity吧
sdk文档中有详细说明
sdk文档中有详细说明
2.Task任务栈的分配
3.Activity如何启动一个service
这个问题开始真是小看了,个人觉得有两种:一种就是start一个service,另外一种就是bind一个service。
百度android
笔试题
java如何同步
wait 和 sleep的区别
java常用的数据结构 如何实现
重载与重写区别
wait 和 sleep的区别
java常用的数据结构 如何实现
重载与重写区别
android 如何提高稳定性
--------------------------------------------------------------
android 有哪些安全机制
android 有哪些安全机制
基于上面两篇文章,我也总结下:1.Android基于Linux,Linux的安全机制适用于Android,通过用户id,组id等实现;2.Android的权限机制:在manifest.xml中会配置相应的权限 3.Android的独立进程机制:每个应用都运行在独立的进程中,互相不干扰,当然他们共享资源和内存等;还有注意shareId如果相同会运行在一个进程中 4.签名机制:Android打包的时候有自己独立的keystore文件,所以这个文件是唯一的,保证应用的安全性
-------------------------------------------------------------
android 应用之间有几种共享数据的方法
android 哪些操作会导致内存泄露 如何排查
.9.png 和 png 的区别
sqlite 使用注意事项
Listview 中 getview中 convertview 的工作原理
service 有什么特征,在哪种情况下会用到service
面试
面试的时候会问你关于简历上的项目,会问得比较细,问你几个人做的,做了多长时间,画出原理图
intent 如何开启activity的?
manifest 的作用
内存过低时,是用什么策略杀死进程@?
1. Intent的几种有关Activity启动的方式有哪些,你了解每个含义吗?
这里Android123提示大家,Intent的一些标记有FLAG_ACTIVITY_BROUGHT_TO_FRONT 、FLAG_ACTIVITY_CLEAR_TOP、FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET、FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS、FLAG_ACTIVITY_MULTIPLE_TASK和FLAG_ACTIVITY_NEW_TASK 等。每种含义大家看SDK文档和具体跑下这样你的记忆会更深刻些。
2. Activity和Task的启动模式有哪些? 每种含义是什么?
有关在AndroidManifest.xml中的android:launchMode定义,主要有standard、singleTop、singleTask和singleInstance,同时对于android:taskAffinity这些问题大家也要了解,Android开发网在以前的文章中讲过,不过很多开发者仍然不是很清楚,这些基础问题我们以后仍然会再次总结。
3. 通过Intent传递一些二进制数据的方法有哪些?
1). 使用Serializable接口实现序列化,这是Java常用的方法。
2). 实现Parcelable接口,这里Android的部分类比如Bitmap类就已经实现了,同时Parcelable在Android AIDL中交换数据也很常见的。
4. 能说下Android应用的入口点吗?
在Google的虚拟机中Application实例中已经实现了main方法,有关具体的Application介绍可以参考 Android程序的入口点是什么,不是Main()吗:http://www.android123.com.cn/kaifafaq/829.html
5. Java基础问题,说说HashSet和HashTable的区别?
这个相信Java程序员都知道HashSet相对于HashMap就是不能存放重复的数据,对于HashTable来说,存放的数据不能出现key或value为null这样的情况。
6. Java基础问题,用Java的集合类写下广度优先搜索.
这个属于基础数据结构问题,通过队列处理一层一层,相对于深度优先的栈处理方式来说更实用一些。
7. Android都有哪些XML解析器,都熟练掌握吗?
这里XmlPull、SAX和DOM相信做过Web开发的都已经滚瓜烂熟了。
8. SQLite支持事务吗? 添加删除如何提高性能?
SQLite作为轻量级的数据库,比MySQL还小,但支持SQL语句查询,提高性能可以考虑通过原始经过优化的SQL查询语句方式处理。
9. Android Service和Binder、AIDL你都熟练吗?
作为Android重要的后台服务,这些每个Android开发者都应该掌握,这也算是和Java SE最大的不同了,具体的实例大家可以查看Android音乐播放器的源代码Music.git中的,这里不再赘述。
- 相关文章
- 面试的几个回答技巧 (36人浏览)
- Android利用GPU高清视频播放的分析 (405人浏览)
- 编译Android源码和Linux内核源码时候遇到的一些错误 (114人浏览)
- 如何在Android上快速显示yuv数据 (685人浏览)
- Android JNI调用C计算代码执行时间(秒) (282人浏览)
- Android NDK开发中解决 UINT64_C was not declar (376人浏览)
- android ndk抛出 signal 11 (SIGSEGV), code (632人浏览)
发表评论(5)
- 1楼 荷兰网 发表于 2015-2-8 1:56:26
- 不错的文章,内容排山倒海. 荷兰网 http://www.zhongguohelanwang.com/
- 2楼 荷兰网 发表于 2015-2-28 1:23:45
- 好文章,内容淋漓尽致. 荷兰网 http://www.zhongguohelanwang.com/
- 3楼 荷兰网 发表于 2015-5-10 15:44:59
- 好文章,内容见缝插针.禁止此消息:nolinkok@163.com 荷兰网 http://www.zhongguohelanwang.com/
- 4楼 荷兰网 发表于 2015-5-27 19:50:08
- 好文章,内容博学多才.禁止此消息:nolinkok@163.com 荷兰网 http://www.zhongguohelanwang.com/
- 5楼 荷兰网 发表于 2015-5-29 0:52:31
- 不错的文章,内容气势磅礴.禁止此消息:nolinkok@163.com 荷兰网 http://www.zhongguohelanwang.com/
查看更多评论>>>