关于面试题
打个比方,如果把找工作理解成考大学,面试就是高考,市面上的“真题”就是模拟试卷。我们会很容易倾向于在面试前寻找对应公司的面试“真题”,重点准备,期待“押题”成功。但实际上,即使面试同一家公司,它会有不同部门,不同业务线,不同面试官,即使遇到同一面试官,他也不一定就每次考察完全一样的内容。想想高考中那些考的好的同学,他们肯定不是靠“押题”才能取得好成绩吧,他们大多靠的是平常积累及对知识点灵活掌握,那面试也一样啊。执着于搜题,把面试题当做重点进行“复习”,还不如自己划出“考纲”,各个知识点逐一检查掌握情况,复习的更全面呢。
我对于面试题的看法一直是相对保守的,这类文章一般只是内容搬运,它会存在一些偏差和误读,最重要的那就是几道题往那一扔,并没有产出有价值的东西。这也是为什么我上篇面试总结,会加了一些面试技巧,整理面试题时,也没提他们是出自哪家公司,就是不希望大家把题目区别看待。
说了这些并不是说面试题没用啊,而是希望大家不要迷信面试题,更多地去关注那些有质量有深度的技术文章。面试考核的是知识点而不是具体的某些题目,面试题的作用在于,衡量我们的知识掌握情况,便于我们查漏补缺,越说越像是针对一次“考试”了。
一、java面试题
熟练掌握java是很关键的,大公司不仅仅要求你会使用几个api,更多的是要你熟悉源码实现原理,甚至要你知道有哪些不足,怎么改进,还有一些java有关的一些算法,设计模式等等。
(一) java基础面试知识点
-
java中==和equals和hashCode的区别
-
int、char、long各占多少字节数
-
int与integer的区别
-
探探对java多态的理解
-
String、StringBuffer、StringBuilder区别
-
什么是内部类?内部类的作用
-
抽象类和接口区别
-
抽象类的意义
-
抽象类与接口的应用场景
-
抽象类是否可以没有方法和属性?
-
接口的意义
-
泛型中extends和super的区别
-
父类的静态方法能否被子类重写
-
进程和线程的区别
-
final,finally,finalize的区别
-
序列化的方式
-
Serializable 和Parcelable 的区别
-
静态属性和静态方法是否可以被继承?是否可以被重写?以及原因?
-
静态内部类的设计意图
-
成员内部类、静态内部类、局部内部类和匿名内部类的理解,以及项目中的应用
-
谈谈对kotlin的理解
-
闭包和局部内部类的区别
-
string 转换成 integer的方式及原理
(二) java深入源码级的面试题(有难度) -
哪些情况下的对象会被垃圾回收机制处理掉?
-
讲一下常见编码方式?
-
utf-8编码中的中文占几个字节;int型几个字节?
-
静态代理和动态代理的区别,什么场景使用?
-
Java的异常体系
-
谈谈你对解析与分派的认识。
-
修改对象A的equals方法的签名,那么使用HashMap存放这个对象实例的时候,会调用哪个equals方法?
-
Java中实现多态的机制是什么?
-
如何将一个Java对象序列化到文件里?
-
说说你对Java反射的理解
-
说说你对Java注解的理解
-
说说你对依赖注入的理解
-
说一下泛型原理,并举例说明
-
Java中String的了解
-
String为什么要设计成不可变的?
-
Object类的equal和hashCode方法重写,为什么?
(三) 数据结构 -
常用数据结构简介
-
并发集合了解哪些?
-
列举java的集合以及集合之间的继承关系
-
集合类以及集合框架
容器类介绍以及之间的区别(容器类估计很多人没听这个词,Java容器主要可以划分为4个部分:List列表、Set集合、Map映射、工具类(Iterator迭代器、Enumeration枚举类、Arrays和Collections),具体的可以看看这篇博文 Java容器类 http://alexyyek.github.io/2015/04/06/Collection/)
-
List,Set,Map的区别
-
List和Map的实现方式以及存储方式
-
HashMap的实现原理
-
HashMap数据结构?
-
HashMap源码理解
-
HashMap如何put数据(从HashMap源码角度讲解)?
-
HashMap怎么手写实现?
-
ConcurrentHashMap的实现原理
-
ArrayMap和HashMap的对比
-
HashTable实现原理
-
TreeMap具体实现
-
HashMap和HashTable的区别
-
HashMap与HashSet的区别
-
HashSet与HashMap怎么判断集合元素重复?
-
集合Set实现Hash怎么防止碰撞
-
ArrayList和LinkedList的区别,以及应用场景
-
数组和链表的区别
-
二叉树的深度优先遍历和广度优先遍历的具体实现
-
堆的结构
-
堆和树的区别
-
堆和栈在内存中的区别是什么(解答提示:可以从数据结构方面以及实际实现方面两个方面去回答)?
-
什么是深拷贝和浅拷贝
-
手写链表逆序代码
-
讲一下对树,B+树的理解
-
讲一下对图的理解
-
判断单链表成环与否?
-
链表翻转(即:翻转一个单项链表)
-
合并多个单有序链表(假设都是递增的)
最后
都说三年是程序员的一个坎,能否晋升或者提高自己的核心竞争力,这几年就十分关键。
技术发展的这么快,从哪些方面开始学习,才能达到高级工程师水平,最后进阶到Android架构师/技术专家?我总结了这 5大块;
我搜集整理过这几年阿里,以及腾讯,字节跳动,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 PDF(实际上比预期多花了不少精力),包含知识脉络 + 分支细节。
Java语言与原理;
大厂,小厂。Android面试先看你熟不熟悉Java语言
高级UI与自定义view;
自定义view,Android开发的基本功。
性能调优;
数据结构算法,设计模式。都是这里面的关键基础和重点需要熟练的。
NDK开发;
未来的方向,高薪必会。
前沿技术;
组件化,热升级,热修复,框架设计
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多,GitHub可见;《Android架构视频+学习笔记》
当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。
不出半年,你就能看出变化!