如何在一个1到100的整数数组中找到丢失的数字?(Google、腾讯)
链表
一个数组插入删除查找和链表的效率对比?如果一个数组要反复插入删除怎能优化降低时间复杂度?(腾讯)
如何在不使用递归的情况下逆转单链表?(小米、快手)
队列&堆栈
一个送礼的场景,礼物各有权重属性,怎么根据权重对礼物进行处理,然后再排队分发,每次取一个礼物,怎么设计数据结构(喜马拉雅、美团)
二叉树
已知前序遍历为{1,2,4,7,3,5,6,8},中序遍历为{4,7,2,1,5,3,8,6},他的二叉树是怎样的(58同城)
排序
top-k排序(堆排序,位图法)美团
查找
设计一个算法,已知某年某月某日是星期几,求另外年月日对应的是星期几(华为)
串
编写一个函数来查找字符串数组中的最长公共前缀
Hashmap常问
1.HashMap的底层原理?线程安全吗?(百度)
2.HashMap中的put是怎么实现的?(滴滴)
3.讲一下HashMap中什么时候需要进行扩容,扩容resize()是如何实现的?(阿里)
4.什么是哈希碰撞?怎么解决(美团)
5.HashMap和HashTable的区别(小米)
6.hashmap concurrenthashmap原理(美团)
7.ArrayList和hashmap的区别,为什么取数更快?
以上真题节选自《一线互联网大厂面试数据结构与算法经典70题》 需要的下伙伴可以在我的GitHub免费下载获取
快速入手通道:点击这里免费自取!
========================================================================
1、介绍下GC回收机制与分代回收策略。
2、如果让你写一段栈溢出的代码你会什么写,一个栈大概有多大,为什么?每个线程都有这样大小的一个栈吗?
3、Java中有几种引用关系,它们的区别是什么?
4、什么情况下会发生栈内存溢出?
5、JVM中一次完整的GC流程是怎样的,对象如何晋升到老年代?
6、Jvm内存 结构说一下。
7、GC收集算法有哪些?它们的特点是什么?
8、描述GC机制。Class会不会回收?用不到的Class怎么回收?(东方头条)
9、如何判断一个对象是否被回收,有哪些GC算法,实际虚拟机使用最多的是什么GC算法?
10、JVM DVM ART的区别(360)
11、请描述new一个对象的流程。
12、StackOverFlow与OOM的区别?分别发生在什么时候,JVM栈中存储的是什么,堆存储的是什么?
13、String, Stringbuffer, StringBuilder 的区别是什么?(东方头条)
14、Java虚拟机和Dalvik虚拟机的区别?
15、Java对象会不会分配到栈中?
16、抽象类和接口的区别。
17、String为什么是不可变的?
18、什么是值传递和引用传递,Java 是值传递还是引用传递?
19、final 、finally、finalize 区别。
20、重载和重写的区别 (京东)
21、try-catch-finally,try里有return,finally还执行么?
22、String s = new String(“”);创建了几个对象?
23、Static class 与non static class的区别。
24、java里 equals和== 区别。
25、Excption与Error区别。
26、描述JVM类加载过程。
27、.PathClassLoader与DexClassLoader的区别是什么?
28、动态代理的方法怎么初始化的?
29、什么是双亲委托机制,为什么需要双亲委托机制?
30、动态代理是什么?如何实现?
…
1、HandlerThread是什么?
3、volatile关键字干了什么?(什么叫指令重排)
4、Synchronized的原理以及与ReentrantLock的区别。(360)
5、Synchronized在JDK1.8之后做了哪些优化
6、什么是守护线程?你是如何退出一个线程的?
7、实现非阻塞式生产者消费者
8、AsyncTask中的任务是串行的还是并行的?
9、AyncTask的原理是什么。
10、有三个线程T1,T2,T3,怎么确保它们按顺序执行?
11、如何开启一个线程,开启大量线程会有什么问题,如何优化?
12、volatile和synchronize有什么区别?
13、sleep 、wait、yield 的区别,wait 的线程如何唤醒它?
14、ReentrantLock的实现原理。
15、假如只有一个cpu,单核,多线程还有用吗 ?
16、Synchronized static与非static锁的区别和范围
17、Android中操作多线程的方式有哪些?
18、怎样获取当前线程是否是主线程
19、HandlerThread是什么?
20、线程间如何通信?
21、RxJava线程切换原理,RxJava1和RxJava2的区别有哪些?
==========================================================================
1、Acitvity的生命周期是什么样的?
2、Activity的4大启动模式,与开发中需要注意的问题,如onNewIntent() 的调用;
3、Intent显示跳转与隐式跳转,如何使用?
4、Activity A跳转B,B跳转C,A不能直接跳转到C,A如何传递消息给C?
5、Activity如何保存状态的?
6、Fragment add与replace的区别,分别对Fragment的生命周期影响
7、 Fragment的构造函数为啥不让传参?(B站)
8、Fragment的生命周期?
9、Application、Activity、Service中context的区别?能否启动一个activity、dialog?
10、什么是有序广播?
11、请描诉Activity的启动流程,从点击图标开始。(B站)
12、 Service的生命周期是什么样的?
13、你会在什么情况下使用Service?
14、startServer和bindServier的区别?
15、Service和Thread的区别?
16、可以再onReceive中开启线程么,会有什么问题?
17、 广播的分类与工作原理
18、 BroadcastReciver的静态注册与动态注册的区别?
19、 ContentProvider如何自定义与使用场景是什么?
20、IntentService与Service的区别?
1、如何优化自定义View
2、Android属性动画实现原理,补间动画实现原理
3、View绘制流程与自定义View注意点。
4、在onResume中可以测量宽高么
5、事件分发机制是什么过程?(东方头条)
6、View分发反向制约的方法?
7、自定义Behavior,NestScroll,NestChild。(东方头条)
8、View.inflater过程与异步inflater(东方头条)
9、.inflater为什么比自定义View慢?(东方头条)
10、onTouchListener onTouchEvent onClick的执行顺序。
11、Requestlayout,onlayout,onDraw,DrawChild区别与联系
12、一个ListView或者一个RecyclerView在显示新闻数据的时候,出现图片错位,可能的原因有哪些 & 如何解决?
13、ScrollView下嵌套一个RecycleView通常会出现什么问题?
14、如何对ListView & RecycleView进行局部刷新的?
15、如何给ListView & RecyclerView加上拉刷新 & 下拉加载更多机制
16、怎么拦截事件 onTouchEvent如果返回false onClick还会执行么?
17、事件的分发机制,责任链模式的优缺点
18、动画的分类以及区别
19、属性动画与普通的动画有什么区别?
20、插值器 估值器的区别
21、RecyclerView与ListView的对比,缓存策略,优缺点。
22、RecyclerView的回收复用机制
23、RecyclerView是什么?如何使用?如何返回不一样的Item
24、WindowMangerService中token到底是什么?有什么区别
25、为什么Dialog不能用Application的Context?
26、如何通过WindowManager添加Window(代码实现)?
27、DecorView, ViewRootImpl,View之间的关系,ViewGroup.add()会多添加一个ViewrootImpl吗
28、自定义View执行invalidate()方法,为什么有时候不会回调onDraw()
29、Android中的动画有哪些? 动画占用大量内存,如何优化
30、.ViewHolder为什么要被声明成静态内部类
31、.ListView卡顿的原因以及优化策略
32、.如何实现Activity窗口快速变暗
33、Activity,Window,View三者的联系和区别
34、View的绘制流程是从Activity的哪个生命周期方法开始执行的
35、invalidate() 和 postInvalicate() 区别
36、View的滑动方式
37、RecyclerView与ListView的对比,缓存策略,优缺点
…
1、LiveData的生命周期如何监听的?(B站)
2、打开多个页面,如何实现一键退出?
3、如果需要在Activity间传递大量的数据怎么办?
4、Android中多进程通信的方式有哪些?
5、描述下Binder机制原理?(东方头条)
6、Binder线程池的工作过程是什么样?
7、Handler怎么进行线程通信,原理是什么?(东方头条)
8、Handler如果没有消息处理是阻塞的还是非阻塞的?
9、handler.post(Runnable) runnable是如何执行的?
10、handler的Callback和handlemessage都存在,但callback返回true handleMessage还会执行么?
11、Handler的sendMessage和postDelay的区别?
12、IdleHandler是什么?怎么使用,能解决什么问题?
13、为什么Looper.loop不阻塞主线程?Looper无限循环为啥没有ANR(B站)
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
学习福利
【Android 详细知识点思维脑图(技能树)】
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
去面试时先看看自己复习到了哪个阶段就好。
虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
[外链图片转存中…(img-V907q6tl-1712005395418)]
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。