很多同学想进大厂,特地是刚毕业的,以及工作年限短的,不要有任何侥幸心理,踏踏实实的把根底弄扎实了,这是你 通往高薪之路的惟一正确姿态。
首先从面试题做起~ 好了,不多说了,间接上正菜。
01 Mysql
1. 数据库三范式及判断、E- R 图
2. innodb 和 myisam 存储引擎的区别
3. 索引分类(主键、惟一索引、全文索引、笼罩索引等等),最左前缀准则,哪些条件无奈应用索引
4. B 树、B+ 树区别,索引为何应用 B + 树
5. 汇集索引与非汇集索引(应用非汇集索引的查问过程)
6. 事务的 ACID(原子性、一致性、隔离性、持久性)
7. 事务隔离级别和各自存在的问题(脏读、不可反复读、幻读)和解决形式(间隙锁及 MVCC)
8. 乐观锁和乐观锁、行锁与表锁、共享锁与排他锁(inndob 如何手动加共享锁与排他锁)
9. MVCC(减少两个版本号)及 delete、update、select 时的具体管制
10. 死锁断定原理和具体场景
11. 查问迟缓和解决形式(explain、慢查问日志、show profile 等)
12. drop、truncate、delete 区别
13. 查问语句不同元素(where、jion、limit、group by、having 等等)执行先后顺序
14. mysql 优化,读写拆散、主从复制
15. 数据库解体时事务的复原机制(REDO 日志和 UNDO 日志)
02 Redis
1. Redis 如何做高可用、集群
2.Redis 和 Memcached 的优劣势比拟
3.Redis 的数据存储类型有哪些?
4.Redis 的利用场景有哪些?
5. Redis 的长久化形式,以及我的项目中用的哪种
6.Redis 的缓存雪崩怎么解决?
7.Redis 与数据库 MySQL 的双写统一如何解决?
8.Redis 的缓存穿透怎么解决?
03 计算机网络
1. OSI 七层协定、TCP/IP 四层协定
2. 各层对应的网络设备(路由器、交换机、网关、网桥、集线器等等),各层对应的协定
3. 数据链路层的 CSMA/CD 协定,口试可能会用到
4. IP 地址分类,子网划分(口试罕用)
5. TCP 和 UDP 的区别
6. TCP 三次握手和四次挥手,为什么三次握手,为什么四次挥手
7. TCP 精华问题:进行期待协定、间断 ARQ 协定、滑动窗口、流量管制、拥塞管制(慢开始、拥塞防止、快重传、快复原)
8. HTTP 状态码
9. HTTP 缓存机制(cache-control、Expires 之类的一系列申请与相应报头字段)
10. session 和 cookie 的区别,禁用 cookie 后怎么办
11. DNS 解析的过程
12. 罕用协定的端口
04 数据结构与算法
1. 数组、链表(单向、双向、双端)、栈和队列、二叉树、红黑树、哈希表、堆(最大和最小)
2. 集体教训:栈和队列、哈希表、链表、二叉树的题较多,图的较少
3. 查找:二分查找及其变形
4. 二叉树:前序、中序、后序遍历,按规定形式打印,两个节点之间操作(最近公共先人、间隔)等问题。
5. 最大堆和最小堆:大数量级数据找最大几个等问题、堆如何调整等问题。
6. 栈和队列:常常作为算法题要用到的数据结构
7. 八大排序:3 个简略的:冒泡、抉择、插入及其优化,5 个高级的:疾速排序、归并排序、堆排序、希尔排序、桶排序(快排、归并、堆很重要)
8. 手写堆排序
9. 给阿里 2 万多名员工按年龄排序应该抉择哪个算法?
05 Linux
1. 常用命令:用户管制、权限管制、过程管制、零碎状态查问之类的
2. /etc/hosts 文件什么做用?
3 Linux 目录构造(尤其是 /proc 十分重要)
4. linux 文件系统构造和启动流程)
5. Java 服务端问题排查(OOM,CPU 高,Load 高,类抵触)
6. 如何查看 Java 利用的线程信息
7.Thread dump 文件如何剖析(Runnable,锁,代码栈,操作系统线程 ID 关联)
06 操作系统
1. 一个二进制文件运行出后果,操作系统做了什么(这是一个很全面的题)
2. 死锁的条件及银行家算法、资源分配图之类的
3. 过程间通信形式
4. linux 的五种 IO 形式(阻塞与非阻塞、同步与异步的了解)
5. linux 的 select、poll、epoll 的区别
6. 过程与线程区别、内核级线程与用户级线程
7. 页面置换算法,尤其是 lru
8. 过程调度算法
9. linux 中断响应机制
10. 虚拟内存机制
08 Java 编程
1. 谈谈对 Synchronized 关键字,类锁,办法锁,重入锁的了解
2. volatile 的原理
3. java 线程的状态及互相转换
4. 线程同步的几种形式和线程间通信
5. ArrayList 和 LinkedList 外部的实现大抵是怎么的?他们之间的区别和优缺点?
6. HashMap 实现原理,如何保障 HashMap 的线程平安
7. ReentrantLock 的外部实现?
8. JVM 的垃圾回收机制,以及回收算法有哪些?
9. JVM 什么时候会触发 YGC,什么时候触发 FGC?
10.JVM 如何内存调优、内存透露如何排查
11. Spring 框架中 IOC 的原理是什么?
12. 用 Spring 如何实现一个切面?
13. 死锁的四个必要条件?
14. 常见的设计模式、手写一个单例、JDK、Spring 原理里有哪些采纳了设计模式。
15. 多线程与高并发的关系和区别
16. 常见的高并发场景有哪些,对应的架构设计计划是什么。
17. 介绍残缺的分布式中间件有哪些,各自的利用场景和作用。
18. 双 11 秒杀流动,你的技术架构设计思路。
。。。。。。。更多面试真题以及答案已整顿如下。。。。。。。。。
——答案传送