主要包括如下几个部分:前端
面试,是你们从学校走向社会的第一步。java
互联网公司的校园招聘,从形式上说,面试通常分为 2-3 轮技术面试 +1 轮 HR 面试。可是一些公司确实是没有 HR 面试的,直接就是三轮技术面。git
技术面试中,面试官通常会先就你所应聘的岗位进行相关知识的考察,也叫基础知识和业务逻辑面试。只要你回答的不是特别差,面试官一般会说:“我们写个代码吧”,这个时候就开始了算法面试。程序员
也就是说,一轮技术面试 = 基础知识和业务逻辑面试 + 算法面试。github
在本篇文章中,咱们主要从技术面试聊起。技术面试包括:业务逻辑和基础知识面试。面试
首先是业务逻辑面试 ,也就是讲项目。算法
面试官会对你简历上写的若干个项目其中之一拿出来和你聊聊。在期间,会针对你所作的东西进行深度挖掘。sql
包括:为何要这么作?优缺点分析,假如从新让你作一次,你打算怎么作? 等等。这个环节主要考察咱们对本身作过的项目(实习项目或者校内项目)是否有一个清晰的认识。数据库
关于业务逻辑面试的准备,建议在平时多多思考总结,对项目的数据来源、总体运行框架都应该熟悉掌握。编程
好比说你在某公司实习过程当中,就能够进行总结,而没必要等到快离职的时候慌慌张张的去总结该项目。
接下来是基础知识面试。
Java 开发属于后台开发方向,有人说后台开发很坑,由于须要学习的东西太多了。没错,这个岗位就是须要学习好多东西。包括:本语言(Java/C++/PHP)基础、数据库、网络协议、Linux 系统、计算机原理甚至前端相关知识均可以考察你,并且,并不超纲 。
有时候,你报的是后台开发岗,而且熟悉的是 Java 语言,可是面试官倒是 C++ 开发方向的,就是这么无奈~
好了,闲话少说,让咱们开始分类讲解常见面试知识点。
1)面向对象的特性有哪些?
答:封装、继承和多态。
2)Java 中覆盖和重载是什么意思?
解析:覆盖和重载是比较重要的基础知识点,而且容易混淆,因此面试中常见。
答:覆盖(Override)是指子类对父类方法的一种重写,只能比父类抛出更少的异常,访问权限不能比父类的小。
被覆盖的方法不能是 private 的,不然只是在子类中从新定义了一个方法;重载(Overload)表示同一个类中能够有多个名称相同的方法,但这些方法的参数列表各不相同。
面试官: 那么构成重载的条件有哪些?
答:参数类型不一样、参数个数不一样、参数顺序不一样。
面试官: 函数的返回值不一样能够构成重载吗?为何?
答:不能够,由于 Java 中调用函数并不须要强制赋值。举例以下:
以下两个方法:
1
2
|
void f(){}
int f(){ return 1 ;}
|
只要编译器能够根据语境明确判断出语义,好比在 int x = f();中,那么的确能够据此区分重载方法。不过, 有时你并不关心方法的返回值,你想要的是方法调用的其余效果 (这常被称为 “为了反作用而调用”),这时你可能会调用方法而忽略其返回值,因此若是像下面的调用:
1
|
fun();
|
此时 Java 如何才能判断调用的是哪个 f() 呢?别人如何理解这种代码呢?因此,根据方法返回值来区分重载方法是行不通的。
3)抽象类和接口的区别有哪些?
答:
面试官:抽象类和接口如何选择?
答:
4)Java 和 C++ 的区别:
解析:虽然咱们不太懂 C++,可是就是会这么问,尤为是三面(总监级别)面试中。
答:
5)Java 中的值传递和引用传递
解析:这类题目,面试官会手写一个例子,让你说出函数执行结果,详细举例请查阅个人博客:Java 值传递和引用传递基础分析。
答:值传递是指对象被值传递,意味着传递了对象的一个副本,即便副本被改变,也不会影响源对象。引用传递是指对象被引用传递,意味着传递的并非实际的对象,而是对象的引用。
所以,外部对引用对象的改变会反映到全部的对象上。
6)JDK 中经常使用的包有哪些?
答:java.lang、java.util、http://java.io、http://java.net、java.sql。
7)JDK,JRE 和 JVM 的联系和区别:
答:JDK 是 java 开发工具包,是 java 开发环境的核心组件,并提供编译、调试和运行一个 java 程序所须要的全部工具,可执行文件和二进制文件,是一个平台特定的软件。
JRE 是 java 运行时环境,是 JVM 的实施实现,提供了运行 java 程序的平台。JRE 包含了 JVM,可是不包含 java 编译器 / 调试器之类的开发工具。
JVM 是 java 虚拟机,当咱们运行一个程序时,JVM 负责将字节码转换为特定机器代码,JVM 提供了内存管理 / 垃圾回收和安全机制等。
这种独立于硬件和操做系统,正是 java 程序能够一次编写多处执行的缘由。
区别:
Others:限于篇幅,面试中 Java 基础知识点还有:反射、泛型、注解等。
小结:本节主要阐述了 Java 基础知识点,这些问题主要是一面面试官在考察,难度不大,适当复习下,应该没什么问题。
集合这方面的考察至关多,这部分是面试中必考的知识点。
1)说说常见的集合有哪些吧?
答:Map 接口和 Collection 接口是全部集合框架的父接口:
(2)HashMap 和 Hashtable 的区别有哪些?(必问)
答:
3)HashMap 的底层实现你知道吗?
答:在 Java8 以前,其底层实现是数组 + 链表实现,Java8 使用了数组 + 链表 + 红黑树实现。此时你能够简单的在纸上画图分析:
4)ConcurrentHashMap 和 Hashtable 的区别? (必问)
答:ConcurrentHashMap 结合了 HashMap 和 HashTable 两者的优点。HashMap 没有考虑同步,hashtable 考虑了同步的问题。可是 hashtable 在每次同步执行时都要锁住整个结构。 ConcurrentHashMap 锁的方式是稍微细粒度的。 ConcurrentHashMap 将 hash 表分为 16 个桶(默认值),诸如 get,put,remove 等经常使用操做只锁当前须要用到的桶。
面试官:ConcurrentHashMap 的具体实现知道吗?
答:
5)HashMap 的长度为何是 2 的幂次方?
答:
更糟的是这种状况中,数组可使用的位置比数组长度小了不少,这意味着进一步增长了碰撞的概率,减慢了查询的效率!这样就会形成空间的浪费。
6)List 和 Set 的区别是啥?
答:List 元素是有序的,能够重复;Set 元素是无序的,不能够重复。
7)List、Set 和 Map 的初始容量和加载因子
答:
1. List
2. Set
HashSet,初始容量为 16,加载因子为 0.75; 扩容增量:原容量的 1 倍; 如 HashSet 的容量为 16,一次扩容后容量为 32
3. Map
HashMap,初始容量 16,加载因子为 0.75; 扩容增量:原容量的 1 倍; 如 HashMap 的容量为 16,一次扩容后容量为 32
8)Comparable 接口和 Comparator 接口有什么区别?
答:
9)Java 集合的快速失败机制 “fail-fast”
答:它是 java 集合的一种错误检测机制,当多个线程对集合进行结构上的改变的操做时,有可能会产生 fail-fast 机制。
例如 :假设存在两个线程(线程 一、线程 2),线程 1 经过 Iterator 在遍历集合 A 中的元素,在某个时候线程 2 修改了集合 A 的结构(是结构上面的修改,而不是简单的修改集合元素的内容),那么这个时候程序就会抛出 ConcurrentModificationException 异常,从而产生 fail-fast 机制。
缘由: 迭代器在遍历时直接访问集合中的内容,而且在遍历过程当中使用一个 modCount 变量。集合在被遍历期间若是内容发生变化,就会改变 modCount 的值。
每当迭代器使用 hashNext()/next() 遍历下一个元素以前,都会检测 modCount 变量是否为 expectedmodCount 值,是的话就返回遍历;不然抛出异常,终止遍历。
解决办法:
小结:本小节是 Java 中关于集合的考察,是 Java 岗位面试中必考的知识点,除了应该掌握以上的问题,包括各个集合的底层实现也建议各位同窗阅读,加深理解。
在 Java 5.0 提供了 java.util.concurrent(简称 JUC )包,在此包中增长了在并发编程中很经常使用的实用工具类,用于定义相似于线程的自定义子系统,包括线程池、异步 IO 和轻量级任务框架。
1)多线程和单线程的区别和联系:
答:
结论:即采用多线程不会提升程序的执行速度,反而会下降速度,可是对于用户来讲,能够减小用户的响应时间。
2)如何指定多个线程的执行顺序?
解析:面试官会给你举个例子,如何让 10 个线程按照顺序打印 0123456789?(写代码实现)
答:
3)线程和进程的区别:(必考)
答:
4)多线程产生死锁的 4 个必要条件?
答:
面试官:如何避免死锁?(常常接着问这个问题哦~)
答:指定获取锁的顺序,举例以下:
5)sleep( ) 和 wait( n)、wait( ) 的区别:
答:
6)synchronized 关键字:
答:底层实现:
含义:(monitor 机制)
Synchronized 是在加锁,加对象锁。对象锁是一种重量锁(monitor),synchronized 的锁机制会根据线程竞争状况在运行时会有偏向锁(单一线程)、轻量锁(多个线程访问 synchronized 区域)、对象锁(重量锁,多个线程存在竞争的状况)、自旋锁等。
该关键字是一个几种锁的封装。
7)volatile 关键字
答:该关键字能够保证可见性不保证原子性。
功能:
解析:关于指令重排序的问题,能够查阅 DCL 双检锁失效相关资料。
8)ThreadLocal(线程局部变量)关键字:
答:当使用 ThreadLocal 维护变量时,其为每一个使用该变量的线程提供独立的变量副本,因此每个线程均可以独立的改变本身的副本,而不会影响其余线程对应的副本。
ThreadLocal 内部实现机制:
9)Atomic 关键字:
答:可使基本数据类型以原子的方式实现自增自减等操做。参考个人博客:concurrent.atomic 包下的类 AtomicInteger 的使用。
10)线程池有了解吗?(必考)
答:java.util.concurrent.ThreadPoolExecutor 类就是一个线程池。客户端调用 ThreadPoolExecutor.submit(Runnable task) 提交任务,线程池内部维护的工做者线程的数量就是该线程池的线程池大小,有 3 种形态:
小结:本小节内容涉及到 Java 中多线程编程,线程安全等知识,是面试中的重点和难点。
既然是 Java 开发面试,那么对 JVM 的考察固然也是必须的,面试官通常会问你对 JVM 有了解吗?
我一般都会把我所了解的都说一遍,包括:JVM 内存划分、JVM 垃圾回收的含义,有哪些 GC 算法,年轻代和老年代各自的特色通通阐述一遍。
1)JVM 内存划分:
2)相似-Xms、-Xmn 这些参数的含义:
答:
堆内存分配:
非堆内存分配:
3)垃圾回收算法有哪些?
答:
此算法须要暂停整个应用,同时,会产生内存碎片;
此算法每次只处理正在使用中的对象,所以复制成本比较小,同时复制过去之后还能进行相应的内存整理,不会出现 “碎片” 问题。固然,此算法的缺点也是很明显的,就是须要两倍内存空间;
此算法避免了 “标记-清除” 的碎片问题,同时也避免了 “复制” 算法的空间问题。
4)root 搜索算法中,哪些能够做为 root?
答:
5)GC 何时开始?
答:GC 常常发生的区域是堆区,堆区还能够细分为新生代、老年代,新生代还分为一个 Eden 区和两个 Survivor 区。
大对象直接进入老年代,如很长的字符串数组,虚拟机提供一个;XX:PretenureSizeThreadhold 参数,令大于这个参数值的对象直接在老年代中分配,避免在 Eden 区和两个 Survivor 区发生大量的内存拷贝;
6)内存泄漏和内存溢出
答:
概念:
内存泄漏的缘由分析:
小结:本小节涉及到 JVM 虚拟机,包括对内存的管理等知识,相对较深。除了以上问题,面试官会继续问你一些比较深的问题,可能也是为了看看你的极限在哪里吧。
好比:内存调优、内存管理,是否遇到过内存泄漏的实际案例、是否真正关心过内存等。因为本人实际项目经验不足,这些深层次问题并无接触过,各位有须要能够上网查阅。
关于 Java8 中新知识点,面试官会让你说说 Java8 你了解多少,下边主要阐述我所了解,而且在面试中回答的 Java8 新增知识点。
1)HashMap 的底层实现有变化:HashMap 是数组 + 链表 + 红黑树(JDK1.8 增长了红黑树部分)实现。
2)JVM 内存管理方面,由元空间代替了永久代。
区别:
3)Lambda 表达式(也称为闭包),容许咱们将函数当成参数传递给某个方法,或者把代码自己当作数据处理。
4)函数式接口:指的是只有一个函数的接口,java.lang.Runnable 和 java.util.concurrent.Callable 就是函数式接口的例子;java8 提供了一个特殊的注解 @Functionallnterface 来标明该接口是一个函数式接口。
5)引入重复注解:Java 8 中使用 @Repeatable 注解定义重复注解。
6)接口中能够实现方法 default 方法。
7) 注解的使用场景拓宽: 注解几乎可使用在任何元素上:局部变量、接口类型、超类和接口实现类,甚至能够用在函数的异常定义上。
8) 新的包 java.time 包
小结:Java8 的一些新特性,面试官通常状况下不要求你有多么精通,主要是看看你有没有一些了解。
网络协议方面,考察最多的包括服务器和客户端在三次握手、四次挥手过程当中的状态变化;还有网络拥塞控制,及其解决办法等。
1)三次握手、四次挥手示意图:
总共有四种状态:主动创建链接、主动断开链接、被动创建连和被动断开链接
两两组合仍是 4 种组合:
2)滑动窗口机制
由发送方和接收方在三次握手阶段,互相将本身的最大可接收的数据量告诉对方。也就是本身的数据接收缓冲池的大小。这样对方能够根据已发送的数据量来计算是否能够接着发送。
在处理过程当中,当接收缓冲池的大小发生变化时,要给对方发送更新窗口大小的通知。
3)拥塞避免机制
拥塞:对资源的需求超过了可用的资源。若网络中许多资源同时供应不足,网络的性能就要明显变坏,整个网络的吞吐量随之负荷的增大而降低。
拥塞控制:防止过多的数据注入到网络中,使得网络中的路由器或链路不致过载。
拥塞控制方法:
4)浏览器中输入:“www.xxx.com” 以后都发生了什么?请详细阐述。
解析:经典的网络协议问题。
答:
5)常见 HTTP 状态码
6)TCP 和 UDP 的区别:
答:
限于篇幅,更多网络协议相关知识,请参阅个人博客:TCP/IP 协议面试常问知识点,倾心总结
小结:必须熟练掌握 TCP 和 UDP 的区别、三次握手和四次挥手的状态切换,必考。
既然是后端开发,那么与数据库相关的知识点也是必不可少的。
1)MySQL 和 MongoDB 的区别有哪些?如何选择?
2)MongoDB 的优缺点有哪些?
(ps 本人对这一块不是很熟悉,就不附上参考答案了,请各位小伙伴自行学习哈~)
3)据说过事务吗?(必考)
答:做为单个逻辑工做单元执行的一系列操做,知足四大特性:
4)事务的并发问题有哪几种?
答:丢失更新、脏读、不可重复读以及幻读。
5)数据库中的锁有哪几种?
答:独占锁、排他锁以及更新锁。
6)事务的隔离级别有哪几种?
答:读未提交、读已提交、可重复读和序列化。
扩展问题:MySQL 事务默认隔离级别是哪一个?
答:可重复读。
解析:关于问题(4)(5)(6)的详细解答,请参阅个人博客:数据库并发机制和事务的隔离级别详解
(ps,关于数据库事务方面的深层次考察还有分布式事务即两段提交和三段提交等,限于本人水平,请各位自行学习)
7)数据库的索引有什么做用?(必考) 底层数据结构是什么,为何使用这种数据结构?
答:
扩展问题:聚簇索引和非聚簇索引的区别?
8)MyISAM 和 InnoDB 的区别有哪些?
答:
最主要的区别是:MyISAM 表不支持事务、不支持行级锁、不支持外键。 InnoDB 表支持事务、支持行级锁、支持外键。(可直接回答这个)
9)数据库中 Where、group by、having 关键字:
答: 关键字做用:
having 和 where 的区别:
当同时含有 where 子句、group by 子句 、having 子句及汇集函数时,执行顺序以下:
10)还有一些问题,如 MySQL 和 SQL Server 用法上的区别、limit 关键字的使用等问题。
小结:数据库方面仍是事务机制、隔离级别比较重要,固然了数据库索引是必考的问题。偶尔也会给你几个表,让你现场写 SQL 语句,主要考察 group by 和 having 等关键字。
我在项目中使用的框架有 Spring MVC 和 MyBatis,因此在简历上只写了这两种框架,面试官主要针对这两种框架进行提问。如下问题供小伙伴们参考。
JavaWeb 开发经典的 3 层框架:Web 层、Service 层(业务逻辑层)和 Dao 层(数据访问层)
Spring 知识点
1)Spring 的 IOC 和 AOP 有了解吗?
答:
2)AOP 的实现方式有哪几种?如何选择?(必考)
答:JDK 动态代理实现和 cglib 实现。
选择:
扩展:JDK 动态代理如何实现?(加分点)
答:JDK 动态代理,只能对实现了接口的类生成代理,而不是针对类,该目标类型实现的接口都将被代理。原理是经过在运行期间建立一个接口的实现类来完成对目标对象的代理。
解析:关于 IOC 和 AOP 的详细阐述,请各位参阅个人博客:Spring 核心 AOP(面向切面编程)总结,Spring 框架学习—控制反转(IOC)
3)Spring MVC 的核心控制器是什么?消息处理流程有哪些?
答:核心控制器为 DispatcherServlet。消息流程以下:
4)其余问题包括:重定向和转发的区别、动态代理和静态代理的区别等。
Mybatis 知识点
关于 MyBatis 主要考察占位符#和 $ 的区别,区别以下:
小结:限于做者水平,MVC 框架方面了解不是太多,实战能力欠缺。面试官偶尔问框架底层实现原理等都知之甚少,有能力的小伙伴能够多加学习。
大数据相关是由于个人简历上写了 KafKa 相关项目,因此面试官会进行提问 KafKa 相关知识点,我也进行了一些简单概念总结,深层次的实现原理由于并无特别多的实战经验,因此并不了解。
如下概念总结供小伙伴参考。
1)KafKa 基本特性:
答:快速持久化、支持批量读写消息、支持消息分区,提升了并发能力、支持在线增长分区、支持为每一个分区建立多个副本。
扩展:为何能够实现快速持久化?
答:KafKa 将消息保存在磁盘中,而且读写磁盘的方式是顺序读写,避免了随机读写磁盘(寻道时间过长)致使的性能瓶颈;磁盘的顺序读写速度超过内存随机读写。
2)核心概念:
答:
副本(replica):
消费者组(Consumer Group): 每一个 consumer 都属于一个 consumer group,每条消息只能被 consumer group 中的一个 Consumer 消费,但能够被多个 consumer group 消费。
Broker:
Cluster&Controller:
保留策略和日志压缩:
关于副本机制:(加分点)
ISR 集合 :表示当前 “可用” 且消息量与 Leader 相差很少的副本集合。知足条件以下:
HW&LEO:
ISR、HW 和 LEO 的工做配合:
KafKa 的容灾机制: 经过分区的副本 Leader 副本和 Follower 副原本提升容灾能力。
小结:请小伙伴根据本身的简历自行准备学习大数据相关知识点。
做者对这一方面不是很精通,知识点来源于网络总结以及面试官的提问,仅供小伙伴参考。
1)grep、sed 以及 awk 命令
解析:awk 命令若是能够掌握,是面试中的一个 加分点。
2)文件和目录:
pwd 显示当前目录
ls 显示当前目录下的文件和目录:
3)处理文件方面的命令有:touch、cp、 In、mv、rm、
4)处理目录方面的命令:mkdir
5)查看文件内容:file、cat、more、less、tail、head
6)监测程序命令:ps、top
eg. 找出进程名中包括 java 的全部进程:ps -ef | grep java
top 命令 实时监测进程
top 命令输出的第一部分:显示系统的归纳。
7)ps 和 top 命令的区别:
8) 压缩数据
9)结束进程:kill PID 或者 kill all
至此,从十个不一样的方面阐述了 Java 开发面试岗位中所涉及到的重要知识点。加上我上次发布的 关于算法面试的 chat,我大概将最近一年的时间内的面试笔试经验给你们作了总结分享。
接下来,为了给你们提供更多的帮助,我想针对简历方面和你们聊聊,主要包括: 制做简历和投递简历两方面。
首先,我想先介绍下个人简历都包括哪些部分:
简历应该突出表现本身优秀的地方,因此我将我的技术博客和 github 地址放到了相对靠前的位置,使面试官或者 HR 能够一眼看到。
各位小伙伴若是在校期间参加过什么大型竞赛而且获奖,也能够写在明显的位置。
给你们一个小提示,那就是必须对简历上所写的知识点有必定了解,不懂的就不要写上去了,由于你会被问的很惨(即便一面面试官不问,三面面试官也会问的)。
好比说你在简历上写了一个技术 A,说本身在项目中使用过技术 A,那么面试官就会问该技术 A 的底层实现、原理等等。
若是你回答出来,确实,这是加分项,可是不少时候咱们是回答不出来的。
投递简历一样很重要,对于并非出身名校的小伙伴来讲,在投递一些互联网公司的时候,可能会面临着简历被刷的可能。这时候内推的重要性就体现出来了。
内推是内部推荐的意思, 内推的好处通常有两种:
内推时间点:
如何内推?
内推,意味着你要找到公司内部人员进行推荐,内推渠道主要是找本身的师兄师姐。另外能够时常关注号称 “全国最大的高校论坛”- 北邮人论坛 。
北邮人论坛资源至关丰富,每一年招聘季的内推帖子数不胜数,各位若是有须要,能够关注一下。在牛客网以及赛码网的讨论区内也存在着大量的内推消息,你们能够关注。