java常见面试题总结

(面的初级到中级之间的,却有很多高级的问题)

总结一些常见的遇见的面试题(来自各方面收集)

1.开发中Java用了比较多的数据结构有哪些?

2.谈谈你对HashMap的理解,底层原理的基本实现,HashMap怎么解决碰撞问题的?

这些数据结构中是线程安全的吗?假如你回答HashMap是线程安全的,接着问你有没有线程安全的map,接下来问conurren包。

3.对JVM熟不熟悉?简单说说类加载过程,里面执行了哪些操作?问了GC和内存管理,平时在tomcat里面有没有进行相关配置

4.然后问了http协议,get和post的基本区别,接着tcp/ip协议,三次握手,窗口滑动机制。

5.开发中用了哪些数据库?回答mysql,存储引擎有哪些?然后问了我悲观锁和乐观锁问题使用场景、分布式集群实现的原理。

6.然后问了我springmvc和mybatis的工作原理,有没有看过底层源码?

 

 

1.如何保障请求执行顺序?

2.分布式事务与分布式锁(扣款不要出现负数)

3.分布式session设置,分布式session一致性

4.执行某操作,前50次成功,第51次失败a全部回滚b前50次提交51次抛异常,ab场景分别如何设置Spring(传播性)

5.Zookeeper有哪些用?

6.JVM的内存模型?

7.数据库垂直和水平拆分

8.Mybatis如何分页;如何设置缓存;Mysql分页

9.IO与NIO的区别,阻塞与非阻塞的区别

10.分布式接口的幂等性设计(不能重复扣款)

 

1.最近做的比较熟悉的项目是哪个?画一下项目技术架构图

2.JVM老年代和新生代的比例?

3.YGC和FGC的发生的具体场景

4.线程池的构造类的方法的5个参数的具体意义?

5.单机上一个线程池正在处理服务,如果突然断电怎么办?(正在处理和阻塞队列里的请求怎么处理?)

6.使用无界阻塞队列会出现什么问题?

7.接口如何处理重复请求

8.具体处理方案是什么?

9.如何保证共享变量修改是的原子性?

10.设计一个对外服务的接口实现类,在1,2,3这三个主机(对应不同ip)上实现负载均衡和顺序轮询机制(考虑并发)

 

1.jvm,jre以及jdk三者之间的关系

2.Dubbo的底层原理,Zookeeper是什么?

3.快速排序;广度优先搜索?

4.缓存的雪崩以及穿透的理解?

5.HashMap的key可以重复吗?

6.synchronized和lock的区别?

7.开发一个大型网站你会考虑哪些问题?

 

面试时,综合准备java Core,数据库,框架,分布式,算法等方面的题目。

初级开发:

1.熟悉SSM架构,至少在项目中做过。用一个业务流程来说明springmvc如何实现的。

2.知道spring mvc的细节,如@Autowired的用法,如何把url映射到Controller上,ModelAndView对象返回的方式等。

3.结合项目的,如何使用AOP,拦截器的,如可以通过拦截器拦截非法请求,怎么用AOP输出日志等。

4.ORM的一对一,一对多,多对多等的用法,以及cascade和inverse的用法

5.声明式事务的做法。

 

1.spring bean的周期

2.spring 的源代码,IOC、AOP、Springmvc的工作流程

3.结合反射,说下IOC的实现原理

4.Spring Boot和Spring Cloud的知识(如spring cloud组件的用法)

 

数据库

1.索引怎么建,怎么用,在哪些场景,什么情况下不该建索引,哪些语句不会使用索引?如在where语句中name like ‘123%’ 会不会使用索引。

2.SQL的优化方案,如分库分表,或通过执行计划查看SQL的优化点。

 

集合

1.hashcode有没有重写过?在什么场景下需要重写。如果可以,结合hash表的算法,说下hashmap的实现原理。ConcurrentHashMap在并发的底层实现代码。

2.ArrayList/LinkedList的差别,比如一个基于数组,一个基于链表,它们均是线程不安全的,ArrayList的扩容做法等。

3.Set如何实现防重,如TreeSet和HashSet等

4.Collection的一些方法,如比较方法、包装成线程安全的方法等。

5.如何通过ArrayList实现队列或堆栈。

 

多线程

1.synchronized和可重入锁的差别,信号量等防并发机制。

2.在线程里该如何返回值(就是 callable runnable的区别),以及并发机制

3.通过ThreadLocal或volatile关键字,说明线程的内存模型

4.线程池的了解及常用参数的了解

 

虚拟机

1.虚拟机的结构图和流程

2.针对堆的垃圾回收机制,画个图,说下年轻代和年老代等

3.说下垃圾回收的流程,然后针对性地说下如何在代码中优化内存性能。

4.如果出现OOM异常,该怎么排查,如何看Dump文件?

 

算法和设计模式

 

 

特别搜集多线程和并发的面试题

1.现在有线程T1、T2和T3。你如何确保T2线程在T1之后执行,并且T3线程在T2之后执行?

  可以使用Thread 的join方法实现这一效果

2.Java中新的Lock接口相对于同步代码块(synchronized block)有什么优势?如何让你实现一个高性能缓存,支持并发读取和单一写入,你如何保障数据完整性。

  多线程和并发编程中使用lock接口的最大优势是它为读和写提供两个单独的锁,可以让你构建高性能数据结构,比如ConcurrentHashMap和条件阻塞。

3.Java中wait和sleep方法有什么区别?

  两者主要区别就是等待释放锁和监视器。sleep方法在等待时不会释放任何锁或监视器。wait方法多用于线程间通信,而sleep只是在执行时暂停。

4.如何在Java中实现一个阻塞队列?

5.如何在Java中编写代码解决生产者和消费者问题?

6.写一段死锁代码。你在Java中如何解决死锁?

7.什么是原子操作?java中有哪些原子操作?你需要同步原子操作吗

8.Java中volatile关键字是什么?你如何使用它,它和Java中的同步方法有什么区别?

9.什么是竞态条件?你如何发现并解决竞态条件?

10.在Java中你如何转储线程(thread dump)?如何分析它?

  在UNIX中,你可以使用kill -3 然后线程转储日志会打印在屏幕上,可以使用CTRL+Break查看。

11.既然start()方法会调用run()方法,为什么我们调用start()方法,而不直接调用run() 方法?

  当你调用start()方法时,它会新建一个线程然后执行run() 方法中的代码。如果直接调用run()方法,并不会创建线程,方法中的代码会在当前调用者的线程中执行。

12.Java中你如何唤醒阻塞线程?

可以中断线程,抛出InterruptedException异常来唤醒。

13.Java中CyclicBarriar和CountDownLatch有什么区别?

14.什么是不可变类?它对于编写并发应用有何帮助?

15.你在多线程环境中遇到的最多的问题是什么?你是如何解决的?

  内存干扰、竞态条件、死锁、活锁、线程饥饿时多线程和并发编程中比较有代表性的问题。这类问题无休无止,而且难于定位和调试。

 

1.Java中绿色线程和本地线程的区别?

2.线程和进程的区别?

3.多线程的上下文切换是什么?

4.死锁和活锁的区别?死锁和饥饿的区别?

5.java中使用什么线程调度算法?

6.Java中线程调度室什么

7.线程中如何处理某个未处理异常?

8.什么是线程组?为什么Java中不建议使用线程组?

9.为什么使用Executor框架比直接创建线程要好?

10.Java中Executor和Executors的区别?

11.在windows和Linux系统上分别入额找到占用CPU最多的线程?

 

    原文作者:java 线程池
    原文地址: http://www.cnblogs.com/sun-flower1314/p/9769691.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞