阿里之路+Java面经考点
Java面试考点梳理
第一部分:计算机基础
互联网大厂都相当重视程序员的基本功,也就是计算机基础知识。一个程序员能走多远、爬多高,很大程度上取决于基本功是否扎实。对于应届生而言,大都比较缺乏实战项目经验,虽然会有一定的项目经验,但这些课程设计、实验室项目的质量与公司实际的项目有着巨大的差距。因此,基础知识便成为面试考量的一大重点,而且基础扎实的程序员可塑性比较高,做什么都能比较容易快速上手。
计算机基础包含如下几门课程,相信计算机专业的同学肯定都已经学过。但互联网公司面试的考点可能和你们期末考试的考点有一些不同,我都做了整理。
1. 计算机网络
大学课程中的计算机网络一般都按照OSI七层参考模型介绍,然而由于互联网公司的特性,他们更加关注日常开发所涉及到的传输层和应用层,所以需要重点掌握传输层和应用层中所涉及到的所有知识点。
【考点】
- 传输层的作用
- 传输层复用和分用的含义
- 传输层和网络层的区别
- UDP协议的特点
- UDP协议的报文结构
- TCP协议的特点
- TCP协议的报文结构
- TCP三次握手过程
- TCP四次挥手过程
- TCP可靠传输是如何实现的
- 停止等待协议
- 滑动窗口协议
- TCP的流量控制
- TCP拥塞控制
- HTTP协议
- HTTP工作流程
- HTTP请求格式
- HTTP 1.1中的8种请求方式
- HTTP响应格式
- HTTP中重要的请求头和响应头字段
- HTTP常用状态码及其含义
- HTTPS协议
- HTTPS协议与HTTP协议的区别
- HTTPS协议的工作流程
2. 数据结构
熟练掌握数据结构是程序员最最最基本的素养,在实际开发中选择合适的数据结构将极大影响程序的效率。面试官一般并不会直接问数据结构的问题,而是通过出一些包含数据结构的算法题来考察你对数据结构的理解程度以及在实际项目中是否能够灵活应用。你可以通过刷算法题来提升这部分能力,推荐《剑指offer》和《程序员面试金典》(注意是金典!)。很多公司的算法题库都选自这两本书。
当然,刷这两本书的目的并不是让你死记硬背题目,题目千变万化,面试官可以随意改变。刷算法题最重要的是培养解决问题的思路和解决实际问题的能力。在刷题的过程中要多多总结,再次强调,切忌死记硬背!
3. 算法
和数据结构一样,算法一般也通过具体的算法题来考察,你也可以通过刷《剑指offer》和《程序员面试金典》中的算法题来提高这方面的技能。但在刷这些算法题之前,你需要掌握几类基础的算法,并理解他们解决问题的思路(这才是最为关键的)。
4. 操作系统
【考点】
- 操作系统的四个特性。
- 操作系统的主要功能。
- 进程的有哪几种状态,状态转换图,及导致转换的事件。
- 进程与线程的区别。
- 进程通信的几种方式。
- 进程同步的几种方式
- 用户态和核心态的区别。
- 死锁的概念,导致死锁的原因。
- 导致死锁的四个必要条件。
- 处理死锁的四个方式。
- 预防死锁的方法、避免死锁的方法。
- 进程调度算法。
- 内存连续分配方式采用的几种算法及各自优劣。
- 基本分页储存管理方式。
- 基本分段储存管理方式。
- 分段分页方式的比较各自优缺点。
- 几种页面置换算***算所需换页数
- 虚拟内存的定义及实现方式。
5. 数据库
【考点】
- 什么是索引?
- 索引的分类
- 索引的优缺点分析
- 何时需要使用索引?何时无需使用索引?
- 什么是事务?
- 事务的四大特性
- 数据库三大范式
- 数据库有哪些表连接?
第二部分:Java
作为一名合格的Java程序员,仅了解如何使用Java是远远不够的。你能够熟练使用Java只能说明你已经成为一名合格的码农,能够利用Java实现某些功能。而公司作为盈利机构,需要用最少的资源实现效益最大化,这就需要程序员具备高质量代码的能力,而能否写出高质量代码取决于你对技术背后原理的理解程度。只有在理解Java背后的原理,你才能根据Java的特性,写出更加高效的代码。这在实际业务中是非常有价值的事情。互联网大厂服务海量用户,更加注重系统的性能,也更加注重程序员对原理的理解。
关于Java的基础知识和如何使用,这里我就不提了,随便一本Java书籍都有详细的介绍。这里我整理了Java原理性的知识点,这些知识点将会成为你面试的加分项。
1. Java虚拟机
【考点】
- Java虚拟机内存模型特点和作用
- 程序计数器
- Java虚拟机栈
- 本地方法区
- 堆
- 方法区
- 对象创建过程
- 对象访问过程
- 对象的内存结构
- 垃圾收集算法
- 如何判定哪些对象需要回收?
- 对象内存分配策略
- 分配担保机制
- 垃圾收集器的比较
- Class文件结构
- 类加载的时机
- 类加载过程
- 双亲委派模型
-
2. Java并发编程
【考点】
- 什么是死锁?如何避免死锁?
- 什么是重排序?
- volatile有哪些特性?
- 什么是内存可见性?
- volatile为什么能够保证内存可见性?
- 中断机制
- 线程通信有哪些方式?
- 线程池的作用?
- ThreadPoolExecutor如何使用?
- 如何设置线程池的大小?
- 如何保证线程安全?
- JDK 1.6哪些对锁做了哪些优化?