作者:茶轴地青春 链接:https://www.nowcoder.com/discuss/71802 来源:牛客网
项目介绍 大部分情况,这是一场面试的开门题,面试官问这个问题,主要是考察你的概述能力和全局视野。有的人经常抱怨自己每天在堆业务,但没有成长。事实上,很多情况下确实在堆业务,但并不是没有成长的。并非做中间件或者技术架构才是成长,例如我们的需求分析能力,沟通协作能力,产品思维能力,抽象建模能力等都是一个非常重要的硬实力。
好的,现在进入正文。
1、明确项目是做什么的
2、明确项目的价值。(为什么做这个项目,它解决了用户什么痛点,它带来什么价值?)
3、明确项目的功能。(这个项目涉及哪些功能?)
4、明确项目的技术。(这个项目用到哪些技术?)
5、明确个人在项目中的位置和作用。(你在这个项目的承担角色?)
6、明确项目的整体架构。
7、明确项目的优缺点,如果重新设计你会如何设计。
8、明确项目的亮点。(这个项目有什么亮点?)
9、明确技术成长。(你通过这个项目有哪些技术成长?)
Java基础
1、List 和 Set 的区别
https://www.cnblogs.com/IvesHe/p/6108933.html
2、HashSet 是如何保证不重复的
https://blog.csdn.net/u010698072/article/details/52802179
3、HashMap 是线程安全的吗,为什么不是线程安全的(最好画图说明多线程环境下不安全)?
https://blog.csdn.net/yiifaa/article/details/77072622
4、HashMap 的扩容过程
https://blog.csdn.net/aichuanwendang/article/details/53317351
https://tech.meituan.com/java-hashmap.html
5、HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的?
https://blog.csdn.net/jek123456/article/details/73869203
6、final finally finalize
https://blog.csdn.net/cyl101816/article/details/67640843
7、强引用 、软引用、 弱引用、虚引用
https://www.cnblogs.com/yw-ah/p/5830458.html
8、Java反射
https://blog.csdn.net/sinat_38259539/article/details/71799078
9、Arrays.sort 实现原理和 Collection 实现原理
https://blog.csdn.net/u011410529/article/details/56668545
10、LinkedHashMap的应用
https://blog.csdn.net/kiss_the_sun/article/details/7848920
11、cloneable接口实现原理
https://blog.csdn.net/u013916933/article/details/51590332( cloneable是java的一种接口的实现形式)
12、异常分类以及处理机制
https://blog.csdn.net/weixin_35813749/article/details/53607376
13、wait和sleep的区别
https://blog.csdn.net/xyh269/article/details/52613507
14、数组在内存中如何分配
https://blog.csdn.net/lcl19970203/article/details/54428358
Java 并发
1、synchronized 的实现原理以及锁优化?
synchronized可以保证方法或者代码块在运行时,同一时刻只有一个方法可以进入到临界区,同时它还可以保证共享变量的内存可见性(https://blog.csdn.net/shandian000/article/details/54927876)
2、volatile 的实现原理?
Java语言规范第三版中对volatile的定义如下: java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致的更新,线程应该确保通过排他锁单独获得这个变量。Java语言提供了volatile,在某些情况下比锁更加方便。如果一个字段被声明成volatile,java线程内存模型确保所有线程看到这个变量的值是一致的。 (http://www.importnew.com/17394.html)
3、Java 的信号灯?
https://blog.csdn.net/u011613354/article/details/51150248
4、synchronized 在静态方法和普通方法的区别?
synchronized修饰不加static的方法,锁是加在单个对象上,不同的对象没有竞争关系;修饰加了static的方法,锁是加载类上,这个类所有的对象竞争一把锁。(https://www.cnblogs.com/guiqulai/articles/7342006.html)
5、怎么实现所有线程在等待某个事件的发生才会去执行?
6、CAS?CAS 有什么缺陷,如何解决?
7、synchronized 和 lock 有什么区别?
8、Hashtable 是怎么加锁的 ?
https://blog.csdn.net/ljg472010941/article/details/7329202
https://blog.csdn.net/u012403290/article/details/64910926?locationNum=11&fps=1
9、HashMap 的并发问题?
https://blog.csdn.net/zhuqiuhui/article/details/51849692
10、ConcurrenHashMap 介绍?1.8 中为什么要用红黑树?
红黑树的使用提高了数据的检索速度,时间的复杂度为O(lgn),当链表的个数达到8个时, 便会转成红黑树,http://www.importnew.com/23621.html
11、AQS
12、如何检测死锁?怎么预防死锁?
13、Java 内存模型? file 14、如何保证多线程下 i++ 结果正确?
在声明变量前添加AtomicInteger关键字,含义为:AtomicInteger是在使用非阻塞算法实现并发控制,在一些高并发程序中非常适合,但并不能每一种场景都适合,不同场景要使用使用不同的数值类。AtomicInteger是一个提供原子操作的Integer类,通过线程安全的方式操作加减。
15、线程池的种类,区别和使用场景?
https://www.cnblogs.com/sachen/p/7401959.html
16、分析线程池的实现原理和线程的调度过程?
17、线程池如何调优,最大数目如何确认?
https://www.cnblogs.com/jianzh5/p/6437315.html
18、ThreadLocal原理,用的时候需要注意什么?
https://blog.csdn.net/sonny543/article/details/51336457
19、CountDownLatch 和 CyclicBarrier 的用法,以及相互之间的差别?
20、LockSupport工具
https://blog.csdn.net/opensure/article/details/53349698
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和AIO
2、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 性能优化
https://www.cnblogs.com/claireyuancy/p/7258314.html
https://www.cnblogs.com/claireyuancy/p/7258314.html
6、mysql的索引分类:B+,hash;什么情况用什么索引
7、事务的特性和隔离级别
https://www.cnblogs.com/fjdingsd/p/5273008.html
缓存
1、Redis用过哪些数据数据,以及Redis底层怎么实现
https://blog.csdn.net/caishenfans/article/details/44784131
2、Redis缓存穿透,缓存雪崩
https://www.cnblogs.com/zhangweizhong/p/6258797.html
3、如何使用Redis来实现分布式锁
4、Redis的并发竞争问题如何解决
5、Redis持久化的几种方式,优缺点是什么,怎么实现的
6、Redis的缓存失效策略
7、Redis集群,高可用,原理
8、Redis缓存分片
9、Redis的数据淘汰策略
JVM
1、详细jvm内存模型 file 2、讲讲什么情况下回出现内存溢出,内存泄漏?
1>当程序在申请内存后,,无法释放已经申请的内存空间(例如一个对象或者变量使用完成后没有释放,这个对对象一直占用着内存),一次内存泄漏的危害可以忽略,但是内存泄露堆积的后果很严重,无论多少内存,迟早会被占光,内存泄露最终会导致内存溢出 2>当程序申请内存时,没有足够的内存空间供其使用,出现了out of memory;比如申请了一个int,但给他存放了long才能存下的数,就是内存溢出.
3、说说Java线程栈
http://blog.51cto.com/wangzhichao/1748503
4、JVM 年轻代到年老代的晋升过程的判断条件是什么呢?
http://ifeve.com/jvm-yong-generation/
5、JVM 出现 fullGC 很频繁,怎么去线上排查问题?
https://blog.csdn.net/wilsonpeng3/article/details/70064336
https://www.jianshu.com/p/d8e247b1e7b2 (mat工具去排查)
6、类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式?
7、类的实例化顺序
8、JVM垃圾回收机制,何时触发MinorGC等操作
9、JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的
10、各种回收器,各自优缺点,重点CMS、G1
11、各种回收算法
12、OOM错误,stackoverflow错误,permgen space错误
本文由 芒果雪花汁 发布
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
最后编辑时间为: Aug 9, 2019 at 03:38 pm