Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说
大厂面试题目_算法面试经典100题,希望能够帮助你!!!。
前言
每个程序员都拥有大厂梦,我也不例外。我从本科毕业,在面试大厂不断碰壁后最终选择进入了一家小型的互联网公司工作,一待就是三年。在小厂呆久了,整个人都会变得懈怠,互联网行业日新月异,稍微跟不上步伐就会被淘汰。于是我决定再拼一把!
我开始努力加强技术,提升自我,最终成功接到阿里、京东、腾讯、拼多多等十多家大厂的面试邀约,并且都比较顺利的通过了前期面试,拿到了自己理想的offer;以下,我将把我近年来大厂常见整体整理出来分享给需要的伙伴们!!!
面试题分享
Java 基础部分
基本这些公司都会问到相关基础,所以,一般来说基础的准备是必要并且通用的,所以这部分真的很重要。
- HashMap 和 HashTable 以及 CurrentHashMap 的区别。 一般来说,这三个东西基本在面试中 70% 会被问到,而问的方向也不太一样。比如初级的问法是讲讲它们之前的区别,这个我想没什么难度,大多数人还是知道主要核心区别是并发上的处理。此外,内部数据结构的实现、扩容、存取操作这些问题应该是很老生常谈了,这并没有什么好说的,大多数人也都知道。稍微问的深一点的可能会在下面这些点上出问题。哈希碰撞,哈希计算,哈希映射,为什么是头插法,扩容为什么是 2 的幂次等这样的问题。
- synchronized 和 volatile 、ReentrantLock 、CAS 的区别。 这个问题被问频率不在 HashMap 之下,因为并发编程,真的很重要。能问到这几个点的方式真的是太多了,我们能发挥的空间也同样很大。CAS 的 ABA 问题?上面几个东西的特性?使用场景?大概我不用再例举了吧?对了,我多次被问到的一个问题是:synchronized 修饰实例方法和修饰静态方法有啥不一样。
- JVM 类加载机制、垃圾回收算法对比、Java 虚拟机结构等。 这三个问题大概出现概率 40%,基本只需要看我每日一问系列的推文就差不多了吧,希望更清楚明白的可以直接看《深入理解 Java 虚拟机》。当你讲到分代回收算法的时候,不免会被追问到新生对象是怎么从年轻代到老年代的,以及可以作为 root 结点的对象有哪些两个问题。
- Java 的四大引用 四大引用面试出现概率比我想象中要高,我原本以为就强引用、软引用、弱引用、虚引用这四个玩意儿没啥可讲的。实际上也确实没啥好讲的,稍微问的深一些的面试官会和内存泄漏检测原理以及垃圾回收糅杂在一起。
- Java 的泛型,<? super T> 和 <? extends T> 的区别。 Java 泛型还是会在面试中出现的,不过几率不是很高,大概是因为我简历中有提到泛型擦除相关的东西。所以会被问到泛型、泛型擦除、通配符相关的东西。不过这个东西,不应该是为了应付面试,实际开发中真的很重要。
- Java 线程有哪些状态,有哪些锁,各种锁的区别。 这个问题讲真,我也只懂一点皮毛,并且当时回答不是很全面,出现概率的话,不是很高吧。
- final 、finally、finalize 区别。 老生常谈的问题,没啥好说的,实际上这次社招面试也只遇到了两次。比较喜欢追根溯源的面试官可能会对这个 finalize 有点执念,一定希望搞清楚,这玩意儿我们是不是可以真的搞点黑科技骚操作。
- 接口和抽象类的区别。 没想到还被问了一次这个,这玩意儿给我的感觉就是随时都在用,但真要较真,还真不能一口气把所有区别都信手拈来。
- sleep 、wait、yield 的区别,wait 的线程如何唤醒它? 大多数 Android 应用开发并接触不到很多并发相关的东西,不过这玩意儿还是在面试中挺容易出现的。
计算机网络部分
计算机网络部分还是挺容易考察的,不过考察的点不会那么深入。通常来说也就是这些问题:
- TCP 有哪些状态。
- 三次握手、四次挥手。为啥是三次不是两次?
- HTTPS 和 HTTP 的区别。HTTPS 2.0,3.0?
- 浏览器输入一个 URL,按下回车网络传输的流程?
- 喜欢深问一点的还会问到网络架构,每层有些什么协议,FTP 这些相关原理,印象比较深刻的还有一个问题是:TCP 建立连接后,发包频率是怎样的?
Android 部分
Android 很广,所以这里只是简单说下有些什么问题。这个的话其实真的 70% 问题出自你的简历。
- Activity 的生命周期;
- Android 的 4 大启动模式,注意 onNewIntent() 的调用;
- 组件化架构思路,如何从一个老项目一步一步实现组件化,主要问实现思路,考察应试者的架构能力和思考能力。 这一块内容真的很多,你需要考虑的问题很多,哪一步做什么,顺序很重要。
- MVC、MCP、MVVP 的区别和各种使用场景,如何选择适合自己的开发架构?
- Router 原理,如何实现组件间通信,组件化平级调用数据方式。
- 系统打包流程;
- APP 启动流程;
- 如何做启动优化? 冷启动什么的肯定是基础,后续应该还有的是懒加载,丢线程池同步处理,需要注意这里可能会有的坑是,丢线程池如何知道全部完成。
- 事件分发机制。 事件分发已经不是直接让你讲了,会给你具体的场景,比如 A 嵌套 B ,B 嵌套 C,从 C 中心按下,一下滑出到 A,事件分发的过程,这里面肯定会有 ACTION_CANCEL 的相关调用时机。
- 如何检测卡顿,卡顿原理是什么,怎么判断是页面响应卡顿还是逻辑处理造成的卡顿?
- 生产者模式和消费者模式的区别?
- 单例模式双重加锁,为什么要这样做。
- Handler 机制原理,IdleHandler 什么时候调用。
- LeakCanary 原理,为什么检测内存泄漏需要两次?
- BlockCanary 原理。
- ViewGroup 绘制顺序;
- Android 有哪些存储数据的方式。
- SharedPrefrence 源码和问题点;
- 讲讲 Android 的四大组件;
- 属性动画、补间动画、帧动画的区别和使用场景;
- 自定义 ViewGroup 如何实现 FlowLayout?如何实现 FlowLayout 调换顺序?
- 自定义 View 如何实现打桌球效果;
- 自定义 View 如何实现拉弓效果,贝瑟尔曲线原理实现?
- APK 瘦身是怎么做的,只用 armabi-v7a 没有什么问题么? APK 瘦身这个基本是 100% 被面试问到,可能是我简历上提到的原因。
- ListView 和 RecyclerView 区别?RecyclerView 有几层缓存,如何让两个 RecyclerView 共用一个缓存?
- 如何判断一个 APP 在前台还是后台?
- 如何做应用保活?全家桶原理?
- 讲讲你所做过的性能优化。
- Retrofit 在 OkHttp 上做了哪些封装?动态代理和静态代理的区别,是怎么实现的。
- 讲讲轨迹视频的音视频合成原理;
- AIDL 相关;
- Binder 机制,讲讲 Linux 上的 IPC 通信,Binder 有什么优势,Android 上有哪些多进程通信机制?
- RxJava 的线程切换原理。
- OkHttp 和 Volloy 区别;
- Glide 缓存原理,如何设计一个大图加载框架。
- LRUCache 原理;
- 讲讲咕咚项目开发中遇到的最大的一个难题和挑战; 这个问题基本是 95% 必问的一个问题;
- 说说你开发最大的优势点。 出现率同上。
算法
- String 转 int。 核心算法就三行代码,不过临界条件很多,除了判空,还需要注意负数、Integer 的最大最小值边界等;
- 如何判断一个单链表有环?
- 链表翻转;
- 快排;
- 100 亿个单词,找出出现频率最高的单词。要求几种方案;
- 链表每 k 位逆序;
- 镜像二叉树;
- 找出一个无序数组中出现超过一半次数的数字;
- 计算二叉树的最大深度,要求非递归算法。
- String 方式计算加法。
一个好的算法可能极大地提升应用的性能,如果你平时有心的话就会发现在Android源码中也经常能看到算法的身影,感兴趣的可以阅读一下SparseArray的源码。
Android面试资料分享
资料不在于多,而在于精。下面我就简单分享一下曾经对我帮助比较大的几个面试资料
由于文章有着篇幅限制,笔记的内容过多,思虑过后,暂在文章中放入知识点图片
需要完整PDF的同学: 可以私信发送 “面试” 或 “进阶” 即可 免费获取
面试知识点大纲:
知识点目录:
部分内容展示:
需要完整PDF的同学: 可以私信发送 “面试” 或 “进阶” 即可 免费获取
最后我想说:
对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们
技术是无止境的,你需要对自己提交的每一行代码、使用的每一个工具负责,不断挖掘其底层原理,才能使自己的技术升华到更高的层面
Android 架构师之路还很漫长,与君共勉
今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。