我的学习之路
从我高考成绩出来那一刻开始,从我在高考志愿上填上“计算机科学与技术”这几个当时在心中堪称“神圣”的几个字开始,我就已经把进入中国互联网最高殿堂“BAT”作为我整个大学奋斗的目标,哪怕我就读的是一所位于内陆的双非一本大学我也认为我能达成目标。
但是当我踏入大学校门开始,发现一切都与自己想象的不一样。进入学生会希望能够锻炼自己的脸皮与组织能力,却发现我的任务只不过是去查查别人班级的出勤,迎新晚会时站站岗;踌躇满志地参加学校八大团队中的ACM团队的面试,寝室里5个人去笔试却只有我一人没有通过,去找团队负责人霸面,却被戏弄嘲笑(这件事对我打击特别大,现在都还有点耿耿于怀);希望大学教授能够绘声绘色地传授知识,却发现毕业自清华大学的博士教授居然连话都说不清。还好我才大一,充满着干劲和对计算机的兴趣,我开始了自学之路。
在老师还在讲计算机概论时,我就自学完了C语言,然后凭借着自己的兴趣给自己选定了Android开发这条路,从此便一发不可收拾,喜欢上了自己当自己老师的感觉。在大二这一年,做了几个APP,其中几个还上架了酷安,有个千把的下载量,与用户交流的感觉让我成就感大增。
由于准备充分,最后拿到了包括阿里,京东,网易,字节跳动在内的5个offer,谨以此文分享给大家我的面试经验。
高级开发技术面试题
这里讲的是大公司需要用到的一些高端Android技术,这里专门整理了一个文档,希望大家都可以看看。这些题目有点技术含量,需要好点时间去研究一下的。
(一)图片
- 图片库对比
- 图片库的源码分析
- 图片框架缓存实现
- LRUCache原理
- 图片加载原理
- 自己去实现图片库,怎么做?
- Glide源码解析
- Glide使用什么缓存?
- Glide内存缓存如何控制大小?
(二)网络和安全机制
- 网络框架对比和源码分析
- 自己去设计网络请求框架,怎么做?
- okhttp源码
- 网络请求缓存处理,okhttp如何处理网络缓存的
- 从网络加载一个10M的图片,说下注意事项
- TCP的3次握手和四次挥手
- TCP与UDP的区别
- TCP与UDP的应用
- HTTP协议
- HTTP1.0与2.0的区别
- HTTP报文结构
- HTTP与HTTPS的区别以及如何实现安全性
- 如何验证证书的合法性?
- https中哪里用了对称加密,哪里用了非对称加密,对加密算法(如RSA)等是否有了解?
- client如何确定自己发送的消息被server收到?
- 谈谈你对WebSocket的理解
- WebSocket与socket的区别
- 谈谈你对安卓签名的理解。
- 请解释安卓为啥要加签名机制?
- 视频加密传输
- App 是如何沙箱化,为什么要这么做?
- 权限管理系统(底层的权限是如何进行 grant 的)?
(三)数据库
- sqlite升级,增加字段的语句
- 数据库框架对比和源码分析
- 数据库的优化
- 数据库数据迁移问题
(四)算法
- 排序算法有哪些?
- 最快的排序算法是哪个?
- 手写一个冒泡排序
- 手写快速排序代码
- 快速排序的过程、时间复杂度、空间复杂度
- 手写堆排序
- 堆排序过程、时间复杂度及空间复杂度
- 写出你所知道的排序算法及时空复杂度,稳定性
- 二叉树给出根节点和目标节点,找出从根节点到目标节点的路径
- 给阿里2万多名员工按年龄排序应该选择哪个算法?
- GC算法(各种算法的优缺点以及应用场景)
- 蚁群算法与蒙特卡洛算法
- 子串包含问题(KMP 算法)写代码实现
- 一个无序,不重复数组,输出N个元素,使得N个元素的和相加为M,给出时间复杂度、空间复杂度。手写算法
- 万亿级别的两个URL文件A和B,如何求出A和B的差集C(提示:Bit映射->hash分组->多文件读写效率->磁* 盘寻址以及应用层面对寻址的优化)
- 百度POI中如何试下查找最近的商家功能(提示:坐标镜像+R树)。
- 两个不重复的数组集合中,求共同的元素。
- 两个不重复的数组集合中,这两个集合都是海量数据,内存中放不下,怎么求共同的元素?
- 一个文件中有100万个整数,由空格分开,在程序中判断用户输入的整数是否在此文件中。说出最优的方法
- 一张Bitmap所占内存以及内存占用的计算
- 2000万个整数,找出第五十大的数字?
- 烧一根不均匀的绳,从头烧到尾总共需要1个小时。现在有若干条材质相同的绳子,问如何用烧绳的方法* * 来计时一个小时十五分钟呢?
- 求1000以内的水仙花数以及40亿以内的水仙花数
- 5枚硬币,2正3反如何划分为两堆然后通过翻转让两堆中正面向上的硬8币和反面向上的硬币个数相同
- 时针走一圈,时针分针重合几次
- N*N的方格纸,里面有多少个正方形
- x个苹果,一天只能吃一个、两个、或者三个,问多少天可以吃完?
(五)插件化、模块化、组件化、热修复、增量更新、Gradle
- 对热修复和插件化的理解
- 插件化原理分析
- 模块化实现(好处,原因)
- 热修复,插件化
- 项目组件化的理解
- 描述清点击 Android Studio 的 build 按钮后发生了什么
(六)架构设计和设计模式
- 谈谈你对Android设计模式的理解
- MVC MVP MVVM原理和区别
- 你所知道的设计模式有哪些?
- 项目中常用的设计模式
- 手写生产者/消费者模式
- 写出观察者模式的代码
- 适配器模式,装饰者模式,外观模式的异同?
- 用到的一些开源框架,介绍一个看过源码的,内部实现过程。
- 谈谈对RxJava的理解
- RxJava的功能与原理实现
- RxJava的作用,与平时使用的异步操作来比的优缺点
- 说说EventBus作用,实现方式,代替EventBus的方式
- 从0设计一款App整体架构,如何去做?
- 说一款你认为当前比较火的应用并设计(比如:直播APP,P2P金融,小视频等)
- 谈谈对java状态机理解
- Fragment如果在Adapter中使用应该如何解耦?
- Binder机制及底层实现
- 对于应用更新这块是如何做的?(解答:灰度,强制更新,分区域更新)?
- 实现一个Json解析器(可以通过正则提高速度)
- 统计启动时长,标准
(七)性能优化
- 如何对Android 应用进行性能分析以及优化?
- ddms 和 traceView
- 性能优化如何分析systrace?
- 用IDE如何分析内存泄漏?
- Java多线程引发的性能问题,怎么解决?
- 启动页白屏及黑屏解决?
- 启动太慢怎么解决?
- 怎么保证应用启动不卡顿?
- App启动崩溃异常捕捉
- 自定义View注意事项
- 现在下载速度很慢,试从网络协议的角度分析原因,并优化(提示:网络的5层都可以涉及)。
- Https请求慢的解决办法(提示:DNS,携带数据,直接访问IP)
- 如何保持应用的稳定性
- RecyclerView和ListView的性能对比
- ListView的优化
- RecycleView优化
- View渲染
- Bitmap如何处理大图,如一张30M的大图,如何预防OOM
- java中的四种引用的区别以及使用场景
- 强引用置为null,会不会被回收?
(八)NDK、jni、Binder、AIDL、进程通信有关
- 请介绍一下NDK
- 什么是NDK库?
- jni用过吗?
- 如何在jni中注册native函数,有几种注册方式?
- Java如何调用c、c++语言?
- jni如何调用java层代码?
- 进程间通信的方式?
- Binder机制
- 简述IPC?
- 什么是AIDL?
- AIDL解决了什么问题?
- AIDL如何使用?
- Android 上的 Inter-Process-Communication 跨进程通信时如何工作的?
- 多进程场景遇见过么?
- Android进程分类?
- 进程和 Application 的生命周期?
- 进程调度
- 谈谈对进程共享和线程安全的认识
- 谈谈对多进程开发的理解以及多进程应用场景
- 什么是协程?
(九)framework层、ROM定制、Ubuntu、Linux之类的问题
- java虚拟机的特性
- 谈谈对jvm的理解
- JVM内存区域,开线程影响哪块内存
- 对Dalvik、ART虚拟机有什么了解?
- Art和Dalvik对比
虚拟机原理,如何自己设计一个虚拟机(内存管理,类加载,双亲委派) - 谈谈你对双亲委派模型理解
- JVM内存模型,内存区域
- 类加载机制
- 谈谈对ClassLoader(类加载器)的理解
- 谈谈对动态加载(OSGI)的理解
- 内存对象的循环引用及避免
- 内存回收机制、GC回收策略、GC原理时机以及GC对象
- 垃圾回收机制与调用System.gc()区别
- Ubuntu编译安卓系统
- 系统启动流程是什么?(提示:Zygote进程 –> SystemServer进程 –> 各种系统服务 –> 应用进程)
- 大体说清一个应用程序安装到手机上时发生了什么
- 简述Activity启动全部过程
- App启动流程,从点击桌面开始
- 逻辑地址与物理地址,为什么使用逻辑地址?
- Android为每个应用程序分配的内存大小是多少?
- Android中进程内存的分配,能不能自己分配定额内存?
- 进程保活的方式
- 如何保证一个后台服务不被杀死?(相同问题:如何保证service在后台不被kill?)比较省电的方式是什么?
- App中唤醒其他进程的实现方式
跨平台Hybrid 开发
- flutter
- Html5项目实战
- HTML&CSS&JavaScript 实战
- WordPress搭建网站项目实战
- 前端Vue架构
- 前端样式开发
- Weex内置能力
- Weex原生应用
- Weex扩展框架
- WeexUI架构
- 介绍你做过的哪些项目
- 都使用过哪些框架、平台?
- 都使用过哪些自定义控件?
- 研究比较深入的领域有哪些?
- 对业内信息的关注渠道有哪些?
- 最近都读哪些书?
- 有没有什么开源项目?
- 自己最擅长的技术点,最感兴趣的技术领域和技术点
- 项目中用了哪些开源库,如何避免因为引入开源库而导致的安全性和稳定性问题
- 实习过程中做了什么,有什么产出?
小结
由于题目很多整理答案的工作量太大,所以仅限于提供知识点,如果你正在找工作,建议逐个过一遍,不懂的可以群里提问讨论, 需要相关知识点可以查看我的【GitHub】,对于已经掌握的可以忽略以节省时间。
自行学习交流直达链接:【点击获取】
系统学习笔记分享
希望我这些面试总结可以帮助还没有找到工作的伙伴们,传递一份温暖~
网友评论