标签:Java 进阶 面试 实现 复杂度 面经 如何 Android
- 内存泄漏,Handler如何导致Activity内存泄漏,如何
《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享
做检测,引用的链路到GCRoot
-
Fragment生命周期
-
Activity各类启动模式下的切换状态后显示状态
-
屏幕反转Activity的生命周期变化
-
Dialog弹起背后的Activity生命周期发生何种变化?
-
一个应用启动过程,如何与AMS,PMS交互
-
EventBus的实现原理,粘性事件是如何实现的?为什么要用EventBus,其优势在哪里?
-
Retrofit的实现原理结合动态代理来问
-
Picasso与Glide的区别(缓存的差异性)
-
Volley与Okhttp的差异性,Okhttp的实现与其优势
-
多进程的数据库与文件操作该如何实现?
-
Android签名,V1,V2
-
Glide中生命周期如何实现的
-
Glide如何加载一个Gif图
-
对于Android中内存使用中注意的点(围绕内存泄露与内存优化讲)
-
MVP,MVVM,MVC的差异性已经适用场景
-
Android APK为什么不可以在IOS上运行,如何设计可以让其运行?
-
Android系统设计为什么要用虚拟机不直接执行机器码?
-
通过虚拟机运行和直接执行机器码的差异性其各自的优势在哪里?
-
Dalvik和ART的区别
-
Native生命周期如何通知到Web?
-
了解Android中的ANR吗?
-
了解Android中的OOM吗?
-
RecyclerView中的缓存实现原理
-
RecyclerView中ItemDecoration的实现原理
-
Activity,Window,WindowManager,ViewRootImpl如何看这几个的关系
-
广播动态注册和静态注册的差异是什么?
-
Android中进程通信的方式,Binder的优势是什么?
-
SparyArray和ArrayMap的实现原理?
-
使用过Koltin吗?
-
使用过RxJava和Retrofit吗?
-
Web与Native的通讯方式
-
SurfaceView和TextureView的区别
-
Surface为什么要用双缓冲机制?
-
Bitmap大图加载的优化策略?
-
SharePreference的commit和apply的区别
Java相关
-
HashMap和HashTable,ConcurrentHashMap的差别
-
ConcurrentHashMap的1.7和1.8版本差异
-
LinkedHashMap实现原理
-
ArrayDeque实现原理
-
Java Object中有哪些方法?equals和hashCode方法什么时候会被重写?
-
Java中悲观锁与乐观锁,举例并说明其相关实现?
-
CAS实现原理
-
synchronized和ReentrantLock的实现差异
-
synchronized对不同方法的修饰,持有的锁对象的差异
-
ThreadLocal实现原理
-
volatile用法
-
说一下对于泛型的理解
-
泛型擦除
-
什么情况下不会出现泛型擦除
-
说一下对于线程安全的理解,Java中线程安全与不安全的集合类有那些?
-
Java的垃圾回收机制
-
JVM中内存分配机制
-
Java类加载机制
-
平时项目中对于锁的应用
-
Java线程池默认提供了哪些类型?分别适合什么场景?
-
Java线程中interrupt()、interrupted()和isInterrupted()分别代表什么意思?
-
动态代理与静态代理
算法与数据结构篇
对于客户端来说,各大厂基本不会有难度太大的题,难度基本在《剑指Offer》和LeetCode中等难度水平,基本还是都可以做到手写bug free的,对于实现复杂的,面试官也会给予提示或者只是让你讲一些思路就好了,除了百度之外,其它都是需要手写的。因为百度无需手写,考察思路,所以难度上会偏难一些。
-
二维坐标系中有一些点,找出一点直线覆盖尽可能多的点
-
链表表示一个数字,求两个数字相加之和,返回一个链表
-
链表反转
-
二叉树的最低深度路径打印
-
无序数组中查找两个和为某一个值的数字,返回索引值
-
二叉树的后续遍历,非递归实现
-
字符串中最长不重复子串
-
背包问题(最大容量与最大价值)
-
动态规划与递归的差异性,什么问题可以用动态规划,什么问题不可以
-
排序算法类型与复杂度,有没有更优的优化空间
-
排序算法复杂度中nlgn中的lgn是怎么来的
-
堆排序相关,堆排序中的堆与堆栈中堆的差异性
-
两个字符串,求其最长子串?例如abc1234,123bc(暴力方法的复杂度,动态规划的复杂度)
-
什么是完全二叉树?
对于算法问题,需要找到最优解,手写达到Bug free的水平,同时对于各种解决方式都能够给出时间复杂度,同时给出时间复杂度的计算过程。
计算机基础
-
TCP三次握手,四次挥手
-
DNS解析过程
-
Http和Https的区别
-
Https的建立连接过程
-
什么是死锁?如何产生?如何消除?
-
TCP拥塞控制与流量控制实现?
-
弱网下网络请求的处理策略,结合直播场景
-
了解那些设计模式?
-
工厂设计模式的优点在于什么?
-
外观设计模式和策略模式的是如何在项目中应用的?
-
有使用过那些加密算法?
-
怎么理解原子性和可见性?
-
如何保证原子性?
-
Https中数据传输是对称加密还是非对称加密?
-
补码表示方式,int最大值加2后等于多少
其它手写设计
-
LruCache实现
-
生产者,消费者模型
-
微信录音模块设计
-
设计一个日志系统
-
设计一个图片加载框架,你会如何实现?
-
手写一个单例实现
-
设计一个小程序容器,有哪些点需要注意的?
-
如何设计Web与Native通信的鉴权
HR面与Leader面
- HR面
对于HR面基本主要是聊一些过往经历,看一下求职意愿,我觉业务部门决定要人了,HR挂人的概率应该是很小的,然后是聊一下薪资期待,说白了就是围绕其自己的KPI来跟你周旋,价格压低同时保证你有足够的入职意愿。吐槽一下,某公司的HR素质是真的爆炸,问我创业亏了多少钱?女朋友在北京吗?(特码的是准备要包养我?)
- Leader面
你期望的工作内容是什么?你觉得你可以给公司带来什么?当然这个不同公司的面试风格差异性还是挺大的,上述面试的公司感觉素质都还是挺高的,给予面试者充分的尊重。这个环节除非是觉得你的工作内容和薪水期望跟他们可以提供的差距较大,一般都是可以通过的。
面试知识点总结
通过上述问题可以看出,对于面试过程除了原有项目的考察,对于知识点的考察上,主要是Android基础知识,Java基础知识,计算机网络,系统设计,算法,结合上述面试题目和自己准备过程中的一些学习记录,下面通过一个脑图的方式进行一个梳理。
以下是自己结合自己的面试整理出来的,当然并没有完全覆盖到所有的Android知识点,大家可以结合自己的日常项目和一些书籍自己在整理汇总。
Android知识
标签:Java,进阶,面试,实现,复杂度,面经,如何,Android 来源: https://blog.csdn.net/m0_64319112/article/details/121869171
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。