Java面试

面试整体事项

1、简历要准备好,联系方式一定要正确清晰醒目,项目经历按照时间倒序阐述,注意准备描述自己在项目中承担的职责,简历的模板尽量选择简洁的,毕竟程序员大部分还是喜欢简单明了的。

2、一般公司面试是技术面->HR结束。还有些较大的公司面试流程都是电面->现场面->HR->等着。

3、不要觉得HR说让你回去等消息就是GG了,他们也要跟你之前的面试官讨论,再向领导汇报,如果说不急可能还要和其他候选人比较,所以HR让你回去等消息绝对不是说明你完蛋了。

4、面试前准备好自我介绍,1分钟左右就可以,可以写在纸上,电面可以照着念,等你到了现场面了基本也都快背下来你的自我介绍了。

5、准备好扎实的基础,这是一切的根源,没实力怎么都没用的,毕竟我们面试的是相关的技术岗位。

6、面试中可以把你的面试官往你会的知识上引导,如果能够主导聊天过程的话,恭喜你基本成了;不要感觉是警察审问小偷的过程。

7、遇到了设计类题目不要着急,面试官不是为了让你几分钟设计一个高并发高可用设计模式完美的架构,只是想看看你的思路,看看你应变的能力,然后给你些提示看看你能否迅速的调整,而不可能再短期内完成一个完美设计的。

8offer都会有的,不要着急,把面试当成一个交流的过程,心态在面试过程中有时候作用很大的,不要小看这里。

需要准备的知识

1、Java基础

1.1、需要通读HashMap的源码,了解其中的实现原理,并能够叙述JDK8中对HashMap做了怎样的优化。

1.2HaspMap扩容是怎样扩容的,为什么都是2N次幂的大小。

1.3HashMapHashTableConcurrentHashMap的区别。

1.4、极高并发下HashTableConcurrentHashMap哪个性能更好,为什么,如何实现的。

1.5HashMap在高并发下如果没有处理线程安全会有怎样的安全隐患,具体表现是什么。

1.6Object类中的方法。

1.7、接口和抽象类的区别,注意JDK8的接口可以有实现。

1.8Java序列化的方式和相关的使用,例如克隆。

1.9、一个ArrayList在循环过程中删除,会不会出问题,为什么。

1.10@transactional注解在什么情况下会失效,为什么。

2、数据结构和算法

2.1B+

2.2、快速排序,堆排序,插入排序(其实八大排序算法都应该了解

2.3、一致性Hash算法,一致性Hash算法的应用

3、JVM

3.1JVM的内存结构。

3.2JVM方法栈的工作过程,方法栈和本地方法栈有什么区别。

3.3JVM的栈中引用如何和堆中的对象产生关联。

3.4、可以了解一下逃逸分析技术。

3.5GC的常见算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。

3.6、标记清除和标记整理算法的理解以及优缺点。

3.7eden survivor区的比例,为什么是这个比例,eden survivor的工作过程。

3.8JVM如何判断一个对象是否该被GC,可以视为root的都有哪几种类型。

3.9、强、软、弱、虚引用的区别以及GC对他们执行怎样的操作。

3.10Java类加载的过程。

3.11双亲委派模型的过程以及优势。

3.12、常用的JVM调优参数。

3.13dump文件的分析。

3.14Java有没有主动触发GC的方式。

4、多线程

4.1Java实现多线程有哪几种方式。

4.2CallableFuture的了解。

4.3、线程池的参数有哪些,在线程池创建一个线程的过程。

4.4volitile关键字的作用,原理。

4.5synchronized关键字的用法,优缺点。

4.6Lock接口有哪些实现类,使用场景是什么。

4.7、可重入锁的用处及实现原理,写时复制的过程,读写锁,分段锁(ConcurrentHashMap中的segment)。

4.8、悲观锁,乐观锁,优缺点,CAS有什么缺陷,该如何解决。

4.9ABC三个线程如何保证顺序执行。

4.10、线程的状态都有哪些。

4.11sleepwait的区别。

4.12notifynotifyall的区别。

4.13ThreadLocal的了解,实现原理。

5、数据库相关

5.1、常见的数据库优化手段

5.2、索引的优缺点,什么字段上建立索引

5.3、数据库连接池。

5.4durid的常用配置。

6、计算机网络

6.1TCPUDP区别。

6.2、三次握手,四次挥手,为什么要四次挥手。

6.3、长连接和短连接。

6.4、连接池适合长连接还是短连接。

7、设计模式

7.1、观察者模式

7.2、代理模式

7.3、单例模式,有不同写法

7.4、可以考Spring中使用了哪些设计模式

8、分布式相关

8.1、分布式事务的控制。

8.2、分布式锁如何设计。

8.3、分布式session如何设计。

8.4dubbo的组件有哪些,各有什么作用。

8.5zookeeper的负载均衡算法有哪些。

8.6dubbo是如何利用接口就可以通信的。

9、缓存相关

9.1redismemcached的区别。

9.2redis支持哪些数据结构。

9.3redis是单线程的么,所有的工作都是单线程么。

9.4redis如何存储一个String的。

9.5redis的部署方式,主从,集群。

9.7redis的哨兵模式,一个key值如何在redis集群中找到存储在哪里。

9.8redis持久化策略。

10、框架相关

10.1SpringMVCController是如何将参数和前端传来的数据一一对应的。

10.2Mybatis如何找到指定的Mapper的,如何完成查询的。

10.3Quartz是如何完成定时任务的。

10.4、自定义注解的实现。

10.5Spring使用了哪些设计模式。

10.6SpringIOC有什么优势。

10.7Spring如何维护它拥有的bean

11、一些较新的东西

11.1JDK8的新特性,流的概念及优势,为什么有这种优势。

11.2、区块链了解

11.3、如何设计双11交易总额面板,要做到高并发高可用。

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值