写点什么

工作 5 年的阿里 Java 程序员,分享从业心得总结与面试笔记分享

用户头像
周老师
关注
发布于: 2021 年 03 月 22 日

预览:


对工作和知识点的总结:工作第一年,往往是什么都充满新鲜感,什么都学习,冲劲十足的一年;WEB 行业知识更新特别快,今天一个框架的新版本,明天又是另一个新框架,有时往往根据项目的需要来不断学习新东西;所以,很多时候感觉,自己用过的东西真多呀!但是真正深入研究的东西却不多。面试,是跳槽后第一个需要面对的问题;而且不同公司面试的着重点不同;但是却有一个共同点:Java 基础是必考的。


工作第一年,可能问你 String 对象创建的理解,常用的框架是什么等等;工作第三年,就问你 Java 内存分配机制是什么,类是如何加载的等等;工作第五年,就问你常用的设计模式是什么,你在工作中充当什么角色,怎么独立完成一个模块等等;可以看出——这是一个典型的程序员的成长过程:


最新 2020 整理收集的一些面试题(都整理成文档),有很多干货,涵盖了阿里巴巴、腾讯、字节跳动、京东、华为等大厂的 Java 面试真题,不管你是要面试大厂还是普通的互联网公司,这些面试题对你肯定是有帮助的,毕竟大厂一定是行业的发展方向标杆,很多公司的面试官同样会研究大厂的面试题。也有详细的学习规划图,


获取面试资料只需:见文末。


Java 基础


1.JAVA 中的几种数据类型是什么,各自占用多少字节。


2.String 类能被继承吗,为什么。


3. 两个对象的 hashCode() 相同,则 equals() 也一定为 true,对吗?


4. String 属于基础的数据类型吗?


5.Java 中操作字符串都有哪些类?它们之间有什么区别?


6.Java 中 IO 流分为几种?


7.BIO、NIO、AIO 有什么区别?


8.用过哪些 Map 类,都有什么区别,HashMap 时线程安全的吗,并发下使用的 Map 是什么,他们的内部原理分别是什么,比如存储方法,hashcode,扩容,默认容量等。


9. 如何将字符串反转?


10.抽象类必须要有抽象方法吗?


11.普通类和抽象类有哪些区别?


12.抽象类能使用 final 修饰吗?


13.ArrayList 和 LinkedList 有什么区别?


14.ConcurrentHashMap 的数据结构(必考)


15.volatile 作用(必考)


16.Atomic 类如何保证原子性(CAS 操作)(必考)


17.为什么要使用线程池(必考)



Redis


  • Redis 的应用场景

  • Redis 支持的数据类型(必考)

  • zset 跳表的数据结构(必考)

  • Redis 的数据过期策略(必考)

  • Redis 的 LRU 过期策略的具体实现

  • 如何解决 Redis 缓存雪崩,缓存穿透问题

  • Redis 的持久化机制(必考)

  • Redis 为什么是单线程的?

  • 什么是缓存穿透?怎么解决?

  • Redis 持久化有几种方式?

  • Redis 为什么这么快?(必考)

  • Redis 怎么实现分布式锁?

  • Redis 如何做内存优化?

  • Redis 淘汰策略有哪些?

  • Redis 常见的性能问题有哪些?该如何解决?

  • Redis 的使用要注意什么?



ZooKeeper


  • CAP 定理

  • ZAB 协议

  • leader 选举算法和流程

  • zookeeper 是什么?

  • zookeeper 有几种部署模式?

  • zookeeper 怎么保证主从节点的状态同步?



Mysql


  • 事务的基本要素

  • 事务隔离级别(必考)

  • 如何解决事务的并发问题(脏读,幻读)(必考)

  • MVCC 多版本并发控制(必考)

  • binlog,redolog,undolog 都是什么,起什么作用

  • InnoDB 的行锁/表锁

  • myisam 和 innodb 的区别,什么时候选择 myisam

  • 为什么选择 B+树作为索引结构(必考)

  • 索引 B+树的叶子节点都可以存哪些东西(必考)

  • 查询在什么时候不走(预期中的)索引(必考)

  • sql 如何优化

  • explain 是如何解析 sql 的

  • order by 原理



JVM


  • 运行时数据区域(内存模型)(必考)

  • 垃圾回收机制(必考)

  • 垃圾回收算法(必考)

  • Minor GC 和 Full GC 触发条件

  • GC 中 Stop the world(STW)

  • 各垃圾回收器的特点及区别

  • 双亲委派模型

  • JDBC 和双亲委派模型关系

  • JVM 中一次完整的 GC 流程是什么样子的,对象如何晋升到老年代,说说你知道的几种主要的 JVM 参数



Spring


  • Spring 的 IOC/AOP 的实现(必考)

  • 动态代理的实现方式(必考)

  • Spring 如何解决循环依赖(三级缓存)(必考)

  • Spring 的后置处理器

  • Spring 的 @Transactional 如何实现的(必考)

  • Spring 的事务传播级别

  • BeanFactory 和 ApplicationContext 的联系和区别



其他


  • 高并发系统的限流如何实现

  • 高并发秒杀系统的设计

  • 负载均衡如何设计


操作系统篇


  • 进程和线程的区别

  • 进程同步的几种方式

  • 线程间同步的方式

  • 什么是缓冲区溢出。有什么危害,其原因是什么

  • 进程中有哪几种状态

  • 分页和分段有什么区别



多线程篇


  • 多线程的几种实现方式,什么是线程安全

  • volatile 的原理,作用,能代替锁吗?

  • sleep 和 wait 的区别

  • sleep(0)的意义

  • Lock 和 Synchronized 的区别

  • synchronized 的原理是什么,一般用在什么地方(比如加载静态方法和非静态方法的区别)



合理的职业规划


什么是职业规划—-就是你短期或者长期的一个职业计划!大道理不讲,咱简单点。先问你几个问题:


a.你工作几年了,你愿意一直和新入行的新手一样就是个简单的程序员吗?b. 你愿意一直写代码,而不关心其他吗?c. 一个项目的前期需求,设计,后期部署维护,领导找到你,你说咱搞不定,行吗?程序员不是敲代码的机器。第一年太多东西不懂,你可以一切听从老大的安排,敲敲代码,看看数据库,测试自己和别人的代码;但是第二年,你还是这样吗?不可能的,一年的经验你完全可以入行了,是时候该学习怎么进行需求分析,怎么设计数据库,怎么写各类文档,怎么写更好的代码?这是高级程序员的要求!


什么是高级程序员?


具有分析设计能力,能进行技术攻关,而且具有某行业深厚背景的程序员!


所以,一个项目立项后,你要积极的参与到前期设计中,跟老同志们一道思考分析问题,学习经验!OK,你这就成长啦!


千万不要认为程序员就是写代码的哦!!!


而且,通过一个项目的开发,你要能粗略的统计出一个功能的开发时间;比如一个模块有 20 个小功能点,你开发了 80 个小时,每个小功能点平均 2 小时——这时在前期就能评估工作量啦。当然每个人的效率和工作质量是不同的,因人而异,但是大概的工作量应该是可以统计出来的,用于统计一个项目的工作周期;


今天给大家分享在这次跳槽中整理的 Java 面试大纲,其中大部分都是面试过程中的面试题,可以对照这查漏补缺,当然了,这里所列的肯定不可能覆盖全部方式。


好的,现在进入面试题正文。


Java 基础


1、List 和 Set 的区别 2、HashSet 是如何保证不重复的 3、HashMap 是线程安全的吗,为什么不是线程安全的(最好画图说明多线程环境下不安全)?4、HashMap 的扩容过程 5、HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的?6、final finally finalize7、强引用 、软引用、 弱引用、虚引用 8、Java 反射 9、Arrays.sort 实现原理和 Collection 实现原理 10、LinkedHashMap 的应用 11、cloneable 接口实现原理 12、异常分类以及处理机制 13、wait 和 sleep 的区别 14、数组在内存中如何分配


Java 并发


1、synchronized 的实现原理以及锁优化?2、volatile 的实现原理?3、Java 的信号灯?4、synchronized 在静态方法和普通方法的区别?5、怎么实现所有线程在等待某个事件的发生才会去执行?6、CAS?CAS 有什么缺陷,如何解决?7、synchronized 和 lock 有什么区别?8、Hashtable 是怎么加锁的 ?9、HashMap 的并发问题?10、ConcurrenHashMap 介绍?1.8 中为什么要用红黑树?11、AQS12、如何检测死锁?怎么预防死锁?13、Java 内存模型?14、如何保证多线程下 i++ 结果正确?15、线程池的种类,区别和使用场景?16、分析线程池的实现原理和线程的调度过程?17、线程池如何调优,最大数目如何确认?18、ThreadLocal 原理,用的时候需要注意什么?19、CountDownLatch 和 CyclicBarrier 的用法,以及相互之间的差别?20、LockSupport 工具 21、Condition 接口及其实现原理 22、Fork/Join 框架的理解 23、分段锁的原理,锁力度减小的思考 24、八种阻塞队列以及各个阻塞队列的特性


Spring


1、BeanFactory 和 FactoryBean?2、Spring IOC 的理解,其初始化过程?3、BeanFactory 和 ApplicationContext?4、Spring Bean 的生命周期,如何被管理的?5、Spring Bean 的加载过程是怎样的?6、如果要你实现 Spring AOP,请问怎么实现?7、如果要你实现 Spring IOC,你会注意哪些问题?8、Spring 是如何管理事务的,事务管理机制?9、Spring 的不同事务传播行为有哪些,干什么用的?10、Spring 中用到了哪些设计模式?11、Spring MVC 的工作原理?12、Spring 循环注入的原理?13、Spring AOP 的理解,各个术语,他们是怎么相互工作的?14、Spring 如何保证 Controller 并发的安全?


Netty


1、BIO、NIO 和 AIO2、Netty 的各大组件 3、Netty 的线程模型 4、TCP 粘包/拆包的原因及解决方法 5、了解哪几种序列化协议?包括使用场景和如何去选择 6、Netty 的零拷贝实现 7、Netty 的高性能表现在哪些方面


分布式相关


1、Dubbo 的底层实现原理和机制 2、描述一个服务从发布到被消费的详细过程 3、分布式系统怎么做服务治理 4、接口的幂等性的概念 5、消息中间件如何解决消息丢失问题 6、Dubbo 的服务请求失败怎么处理 7、重连机制会不会造成错误 8、对分布式事务的理解 9、如何实现负载均衡,有哪些算法可以实现?10、Zookeeper 的用途,选举的原理是什么?11、数据的垂直拆分水平拆分。12、zookeeper 原理和适用场景 13、zookeeper watch 机制 14、redis/zk 节点宕机如何处理 15、分布式集群下如何做到唯一序列号 16、如何做一个分布式锁 17、用过哪些 MQ,怎么用的,和其他 mq 比较有什么优缺点,MQ 的连接是线程安全的吗 18、MQ 系统的数据如何保证不丢失 19、列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问题 20、zookeeper 的选举策略 21、全局 ID


数据库


1、mysql 分页有什么优化 2、悲观锁、乐观锁 3、组合索引,最左原则 4、mysql 的表锁、行锁 5、mysql 性能优化 6、mysql 的索引分类:B+,hash;什么情况用什么索引 7、事务的特性和隔离级别


缓存


1、Redis 用过哪些数据数据,以及 Redis 底层怎么实现 2、Redis 缓存穿透,缓存雪崩 3、如何使用 Redis 来实现分布式锁 4、Redis 的并发竞争问题如何解决 5、Redis 持久化的几种方式,优缺点是什么,怎么实现的 6、Redis 的缓存失效策略 7、Redis 集群,高可用,原理 8、Redis 缓存分片 9、Redis 的数据淘汰策略


JVM


1、详细 jvm 内存模型 2、讲讲什么情况下会出现内存溢出,内存泄漏?3、说说 Java 线程栈 4、JVM 年轻代到年老代的晋升过程的判断条件是什么呢?5、JVM 出现 fullGC 很频繁,怎么去线上排查问题?6、类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式?7、类的实例化顺序 8、JVM 垃圾回收机制,何时触发 MinorGC 等操作 9、JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的 10、各种回收器,各自优缺点,重点 CMS、G111、各种回收算法 12、OOM 错误,stackoverflow 错误,permgen space 错误


最新 2020 整理收集的一些面试题(都整理成文档),有很多干货,包含 mysql,netty,spring,线程,spring cloud 等详细讲解,也有详细的学习规划图,面试题整理等


欢迎大家扫码来关注公众号博主,获取文章全部资料,此公众号会持续更新技术干货、不定期分享 Java 进阶面试宝典、Java 核心知识、架构书籍电子版


用户头像

周老师

关注

精通java热衷于分享java领域资料,感谢支持 2020.06.09 加入

还未添加个人简介

评论

发布
暂无评论
工作5年的阿里Java程序员,分享从业心得总结与面试笔记分享