Java 多线程面试题
1、多线程有什么用?
2、创建线程的方式
3、start()方法和run()方法的区别
4、Runnable接口和Callable接口的区别
5、CyclicBarrier和CountDownLatch的区别
6、volatile关键字的作用
7、什么是线程安全
8、Java中如何获取到线程dump文件
9、一个线程如果出现了运行时异常会怎么样
10、如何在两个线程之间共享数据
11、sleep方法和wait方法有什么区别
12、生产者消费者模型的作用是什么
13、ThreadLocal有什么用
14、为什么wait()方法和notify()/notifyAll()方法要在同步块中被调用
15、wait()方法和notify()/notifyAll()方法在放弃对象监视器时有什么区别
16、为什么要使用线程池
17、怎么检测一个线程是否持有对象监视器
18、synchronized和ReentrantLock的区别
19、ConcurrentHashMap的并发度是什么
20、ReadWriteLock是什么
21、FutureTask是什么
22、Linux环境下如何查找哪个线程使用CPU最长
23、Java编程写一个会导致死锁的程序
24、怎么唤醒一个阻塞的线程
25、不可变对象对多线程有什么帮助
26、什么是多线程的上下文切换
27、如果你提交任务时,线程池队列已满,这时会发生什么
28、Java中用到的线程调度算法是什么
29、Thread.sleep(0)的作用是什么
30、什么是自旋
31、什么是Java内存模型
32、什么是CAS
33、什么是乐观锁和悲观锁
34、什么是AQS
35、单例模式的线程安全性
36、Semaphore有什么作用
37、Hashtable的size()方法中明明只有一条语句"return count",为什么还要做同步?
38、线程类的构造方法、静态块是被哪个线程调用的
39、同步方法和同步块,哪个是更好的选择
40、高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?
BAT 常问的 Java基础39道常见面试题
1.八种基本数据类型的大小,以及他们的封装类
2.引用数据类型
3.Switch能否用string做参数
4.equals与==的区别
5.自动装箱,常量池
6.Object有哪些公用方法
7.Java的四种引用,强弱软虚,用到的场景
8.Hashcode的作用
9.HashMap的hashcode的作用
10.为什么重载hashCode方法?
11.ArrayList、LinkedList、Vector的区别
12.String、StringBuffer与StringBuilder的区别
13.Map、Set、List、Queue、Stack的特点与用法
14.HashMap和HashTable的区别
15.JDK7与JDK8中HashMap的实现
16.HashMap和ConcurrentHashMap的区别,HashMap的底层源码
17.ConcurrentHashMap能完全替代HashTable吗
18.为什么HashMap是线程不安全的
19.如何线程安全的使用HashMap
20.多并发情况下HashMap是否还会产生死循环
21.TreeMap、HashMap、LindedHashMap的区别
22.Collection包结构,与Collections的区别
23.try?catch?finally,try里有return,finally还执行么
24.Excption与Error包结构,OOM你遇到过哪些情况,SOF你遇到过哪些情况
25.Java(OOP)面向对象的三个特征与含义
26.Override和Overload的含义去区别
27.Interface与abstract类的区别
28.Static?class?与non?static?class的区别
29.foreach与正常for循环效率对比
30.Java?IO与NIO
31.java反射的作用于原理
32.泛型常用特点
33.解析XML的几种方式的原理与特点:DOM、SAX
34.Java1.7与1.8,1.9,10 新特性
35.设计模式:单例、工厂、适配器、责任链、观察者等等
36.JNI的使用
37.AOP是什么
38.OOP是什么
39.AOP与OOP的区别
跳槽必备的100道 Java 面试题
多线程、并发及线程的基础问题
1)Java 中能创建 volatile 数组吗?
2)volatile 能使得一个非原子操作变成原子操作吗?
3)volatile 修饰符的有过什么实践?
4)volatile 类型变量提供什么保证?
5)10 个线程和 2 个线程的同步代码,哪个更容易写?
6)你是如何调用 wait()方法的?使用 if 块还是循环?为什么?
7)什么是多线程环境下的伪共享(false sharing)?
有经验程序员的 Java 面试题
8)什么是 Busy spin?我们为什么要使用它?
9)Java 中怎么获取一份线程 dump 文件?
10)Swing 是线程安全的?
11)什么是线程局部变量?
12)Java 中 sleep 方法和 wait 方法的区别?
13)什么是不可变对象(immutable object)?Java 中怎么创建一个不可变对象?
14)我们能创建一个包含可变对象的不可变对象吗?
15)Java 中应该使用什么数据类型来代表价格?
16)怎么将 byte 转换为 String?
17)Java 中怎样将 bytes 转换为 long 类型?
18)我们能将 int 强制转换为 byte 类型的变量吗?如果该值大于 byte 类型的范围,将会出现什么现象?
19)哪个类包含 clone 方法?是 Cloneable 还是 Object?
20)Java 中 ++ 操作符是线程安全的吗?
21)不是线程安全的操作。它涉及到多个指令,如读取变量值,增加,
22)a = a + b 与 a += b 的区别
23)我能在不进行强制转换的情况下将一个 double 值赋值给 long 类型的变量吗?
24)3*0.1 == 0.3 将会返回什么?true 还是 false?
25)int 和 Integer 哪个会占用更多的内存?
26)为什么 Java 中的 String 是不可变的(Immutable)?
27)我们能在 Switch 中使用 String 吗?
28)Java 中的构造器链是什么?
JVM 底层 与 GC(Garbage Collection) 的面试问题
29)64 位 JVM 中,int 的长度是多数?
30)Serial 与 Parallel GC之间的不同之处?
31)32 位和 64 位的 JVM,int 类型变量的长度是多数?
32)Java 中 WeakReference 与 SoftReference的区别?
33)WeakHashMap 是怎么工作的?
34)JVM 选项 -XX:+UseCompressedOops 有什么作用?为什么要使
35)怎样通过 Java 程序来判断 JVM 是 32 位 还是 64 位?
36)32 位 JVM 和 64 位 JVM 的最大堆内存分别是多数?
37)JRE、JDK、JVM 及 JIT 之间有什么不同?
3 年工作经验的 Java 面试题
38)解释 Java 堆空间及 GC?
39)你能保证 GC 执行吗?
40)怎么获取 Java 程序使用的内存?堆使用的百分比?
41)Java 中堆和栈有什么区别?
Java 基本概念面试题
42)“a==b”和”a.equals(b)”有什么区别?
43)a.hashCode() 有什么用?与 a.equals(b) 有什么关系?
44)final、finalize 和 finally 的不同之处?
45)Java 中的编译期常量是什么?使用它又什么风险?
Java 集合框架的面试题
- List、Set、Map 和 Queue 之间的区别(答案)
47)poll() 方法和 remove() 方法的区别?
48)Java 中 LinkedHashMap 和 PriorityQueue 的区别是什么?
49)ArrayList 与 LinkedList 的不区别?
50)用哪两种方式来实现集合的排序?
51)Java 中怎么打印数组?
52)Java 中的 LinkedList 是单向链表还是双向链表?
53)Java 中的 TreeMap 是采用什么树实现的?(答案)
- Hashtable 与 HashMap 有什么不同之处?
55)Java 中的 HashSet,内部是如何工作的?
56)写一段代码在遍历 ArrayList 时移除一个元素?
57)我们能自己写一个容器类,然后使用 for-each 循环码?
58)ArrayList 和 HashMap 的默认大小是多数?
59)有没有可能两个不相等的对象有有相同的 hashcode?
60)两个相同的对象会有不同的的 hash code 吗?
61)Java 中,Comparator 与 Comparable 有什么不同?
62)为什么在重写 equals 方法的时候需要重写 hashCode 方法?
Java IO 和 NIO 的面试题
63)Java 中怎么创建 ByteBuffer?
Java 最佳实践的面试问题
64)Java 中,编写多线程程序的时候你会遵循哪些最佳实践?
65)说出几点 Java 中使用 Collections 的最佳实践
66)说出 5 条 IO 的最佳实践(答案)
67)说出几条 Java 中方法重载的最佳实践?
Date、Time 及 Calendar 的面试题
68)在多线程环境下,SimpleDateFormat 是线程安全的吗?
单元测试 JUnit 面试题
69)如何测试静态方法?
70)Java 中如何将字符串转换为整数?
关于 OOP 和设计模式的面试题
71)接口是什么?为什么要使用接口而不是直接使用具体类?
72)Java 中,抽象类与接口之间有什么不同?
73)除了单例模式,你在生产环境中还用过什么设计模式?
- 什么情况下会违反迪米特法则?为什么会有这个问题?
75)适配器模式是什么?什么时候使用?
76)什么是“依赖注入”和“控制反转”?为什么有人使用?
77)抽象类是什么?它与接口有什么区别?你为什么要使用过抽象类?
78)构造器注入和 setter 依赖注入,那种方式更好?
79)依赖注入和工程模式之间有什么不同?
80)适配器模式和装饰器模式有什么区别?
81)适配器模式和代理模式之前有什么不同?
82)什么是模板方法模式?
83)什么时候使用访问者模式?
84)什么时候使用组合模式?
85)继承和组合之间有什么不同?
86)描述 Java 中的重载和重写?
87)Java 中,嵌套公共静态类与顶级类有什么不同?
- OOP 中的 组合、聚合和关联有什么区别?
89)给我一个符合开闭原则的设计模式的例子?
90)抽象工厂模式和原型模式之间的区别?
91)什么时候使用享元模式?
Java 面试中其他各式各样的问题
92)嵌套静态类与顶级类有什么区别?
93)你能写出一个正则表达式来判断一个字符串是否是一个数字吗?
94)Java 中,受检查异常 和 不受检查异常的区别?
95)Java 中,throw 和 throws 有什么区别
96)Java 中,Serializable 与 Externalizable 的区别?
97)Java 中,DOM 和 SAX 解析器有什么不同?
98)说出 JDK 1.7 中的三个新特性?
99)说出 5 个 JDK 1.8 引入的新特性?
100)Java 中,Maven 和 ANT 有什么区别?
Java开发岗位面试题归类汇总
一、Java基础
1. String类为什么是final的
2. HashMap的源码,实现原理,底层结构。
3. 说说你知道的几个Java集合类:list、set、queue、map实现类。
4. 描述一下ArrayList和LinkedList各自实现和区别
5. Java中的队列都有哪些,有什么区别。
6. 反射中,Class.forName和classloader的区别。
7. Java7、Java8的新特性
8. Java数组和链表两种结构的操作效率,在哪些情况下(从开头开始,从结尾开始,从中间开始),哪些操作(插入,查找,删除)的效率高。
9. Java内存泄露的问题调查定位:jmap,jstack的使用等等。
10. string、stringbuilder、stringbuffer区别
11. hashtable和hashmap的区别
13 .异常的结构,运行时异常和非运行时异常,各举个例子。
14. String 类的常用方法
16. Java 的引用类型有哪几种
17. 抽象类和接口的区别
18. java的基础类型和字节大小
19. Hashtable,HashMap,ConcurrentHashMap底层实现原理与线程安全问题。
20. 如果不让你用Java Jdk提供的工具,你自己实现一个Map,你怎么做。说了好久,说了HashMap源代码,如果我做,就会借鉴HashMap的原理,说了一通HashMap实现。
21. Hash冲突怎么办?哪些解决散列冲突的方法?
22. HashMap冲突很厉害,最差性能,你会怎么解决?从O(n)提升到log(n)。
23. rehash
24. hashCode() 与 equals() 生成算法、方法怎么重写。
二、Java IO
1. 讲讲IO里面的常见类,字节流、字符流、接口、实现类、方法阻塞。
2. 讲讲NIO
3. String 编码UTF-8 和GBK的区别?
4. 什么时候使用字节流、什么时候使用字符流?
5. 递归读取文件夹下的文件,代码怎么实现?
三、Java Web
1. session和cookie的区别和联系,session的生命周期,多个服务部署时session管理。
2. servlet的一些相关问题
3. webservice相关问题
4. jdbc连接,forname方式的步骤,怎么声明使用一个事务。
5. 无框架下配置web.xml的主要配置内容
6. jsp和servlet的区别
四、JVM
1. Java的内存模型以及GC算法
2. jvm性能调优都做了什么
3. 介绍JVM中7个区域,然后把每个区域可能造成内存的溢出的情况说明。
4. 介绍GC 和GC Root不正常引用
5. 自己从classload 加载方式,加载机制说开去,从程序运行时数据区,讲到内存分配,讲到String常量池,讲到JVM垃圾回收机制,算法,hotspot。
6. jvm 如何分配直接内存, new 对象如何不分配在堆而是栈上,常量池解析。
7. 数组多大放在JVM老年代
8. 老年代中数组的访问方式
9. GC 算法,永久代对象如何 GC , GC 有环怎么处理。
10. 谁会被 GC ,什么时候 GC。
11. 如果想不被 GC 怎么办
12. 如果想在 GC 中生存 1 次怎么办
五、开源框架
1. hibernate和ibatis的区别
2. 讲讲mybatis的连接池
3. spring框架中需要引用哪些jar包,以及这些jar包的用途
4. springMVC的原理
5. springMVC注解的意思
6. spring中beanFactory和ApplicationContext的联系和区别
7. spring注入的几种方式
8. spring如何实现事物管理的
9. springIOC
10. spring AOP的原理
11. hibernate中的1级和2级缓存的使用方式以及区别原理(Lazy-Load的理解)
12. Hibernate的原理体系架构,五大核心接口,Hibernate对象的三种状态转换,事务管理。
六、多线程
1. Java创建线程之后,直接调用start()方法和run()的区别
2. 常用的线程池模式以及不同线程池的使用场景
3. newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。
4. 多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。
5. 了解可重入锁的含义,以及ReentrantLock 和synchronized的区别
6. 同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么他是同步的且效率高。
7. atomicinteger和Volatile等线程安全操作的关键字的理解和使用
8. 线程间通信,wait和notify
9. 定时线程的使用
10. 场景:在一个主线程中,要求有大量(很多很多)子线程执行完之后,主线程才执行完成。多种方式,考虑效率。
11. 进程和线程的区别
12. 什么叫线程安全?
13. 线程的几种状态
14. 并发、同步的接口或方法
15. HashMap 是否线程安全,为何不安全。ConcurrentHashMap,线程安全,为何安全。底层实现是怎么样的。
16. J.U.C下的常见类的使用。ThreadPool的深入考察;BlockingQueue的使用。(take,poll的区别,put,offer的区别);原子类的实现。
17. 简单介绍下多线程的情况,从建立一个线程开始。然后怎么控制同步过程,多线程常用的方法和结构
18. volatile的理解
19. 实现多线程有几种方式,多线程同步怎么做,说说几个线程里常用的方法。
七、网络通信
1. http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。
2. socket通信,以及长连接,分包,连接异常断开的处理。
3. socket通信模型的使用,AIO和NIO。
4. socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞。
5. 同步和异步,阻塞和非阻塞。
6. OSI七层模型,包括TCP,IP的一些基本知识
7. http中,get post的区别
8. 说说http,tcp,udp之间关系和区别。
10. HTTP协议、 HTTPS协议,SSL协议及完整交互过程;
11. tcp的拥塞,快回传,ip的报文丢弃
12. https处理的一个过程,对称加密和非对称加密
13. head各个特点和区别
14. 说说浏览器访问
八、数据库MySql
1. MySql的存储引擎的不同
2. 单个索引、联合索引、主键索引
3. Mysql怎么分表,以及分表后如果想按条件分页查询怎么办
4. 分表之后想让一个id多个表是自增的,效率实现
5. MySql的主从实时备份同步的配置,以及原理(从库读主库的binlog),读写分离。
6. 写SQL语句和SQL优化
7. 索引的数据结构,B+树
8. 事务的四个特性,以及各自的特点(原子、隔离)等等,项目怎么解决这些问题。
9. 数据库的锁:行锁,表锁;乐观锁,悲观锁
10. 数据库事务的几种粒度
11. 关系型和非关系型数据库区别
九、设计模式
1. 单例模式:饱汉、饿汉。以及饿汉中的延迟加载,双重检查。
2. 工厂模式、装饰者模式、观察者模式。
3. 工厂方法模式的优点(低耦合、高内聚,开放封闭原则)
十、算法
1. 使用随机算法产生一个数,要求把1-1000W之间这些数全部生成。
2. 两个有序数组的合并排序
3. 一个数组的倒序
4. 计算一个正整数的正平方根
5. 说白了就是常见的那些查找、排序算法以及各自的时间复杂度。
6. 二叉树的遍历算法
7. DFS,BFS算法
9. 比较重要的数据结构,如链表,队列,栈的基本理解及大致实现。
10. 排序算法与时空复杂度(快排为什么不稳定,为什么你的项目还在用)
11. 逆波兰计算器
12. Hoffman 编码
13. 查找树与红黑树
十一、并发与性能调优
1. 有个每秒钟5k个请求,查询手机号所属地的笔试题,如何设计算法?请求再多,比如5w,如何设计整个系统?
2. 高并发情况下,我们系统是如何支撑大量的请求的
3. 集群如何同步会话状态
4. 负载均衡的原理
5 .如果有一个特别大的访问量,到数据库上,怎么做优化(DB设计,DBIO,SQL优化,Java优化)
6. 如果出现大面积并发,在不增加服务器的基础上,如何解决服务器响应不及时问题“。
7. 假如你的项目出现性能瓶颈了,你觉得可能会是哪些方面,怎么解决问题。
8. 如何查找 造成 性能瓶颈出现的位置,是哪个位置照成性能瓶颈。
9. 你的项目中使用过缓存机制吗?有没用用户非本地缓存
十二、其他
阿里高级java面试题和答案
一面面试题目:
1、你比较了解的机器学习的算法有哪些,说一下这些算法的过程和区别
2、网络的体系结构分为哪五层,每层分别有哪些协议
3、TCP和UDP的区别是什么,如果想发送即时消息应该用哪种协议
4、TCP的连接建立和断开的过程(三次握手和四次挥手),如何保证TCP发送的信息是正确的,且保证其先后顺序不被篡改
5、对HTTP协议了解多少,HTTP和HTTPS有什么区别,HTTPS的安全性是怎么实现的
6、平时用mysql用什么引擎
7、数据库事务的特性有哪些
8、事务并发可能会导致哪些问题,数据库的隔离级别有哪些,mysql默认的是哪种级别,这种默认的隔离级别能够避免哪些问题(复习的太久了,有一些忘记了,这个问题居然答得不全)
9、如何判断SQL查询操作是不是慢sql,如何优化
10、进程和线程的区别,进程之间的通信方法
11、死锁是什么,处理死锁的方法有哪些
12、进程同步中的临界区有什么处理方法
13、spring MVC,spring AOP源码
14、spring循环引用
15、spring事务传播机制
16、java nio,bio,aio,操作系统底层nio实现原理
17、java线程编程了解吗?
18、hashmap的数据结构是什么,具体是怎么实现的,是不是线程安全的(不是),那么它的线程安全的替代有哪些?
二面面试题目和参考答案:
你在项目中遇到哪些有挑战性的点?
参考:参与了秒杀的高并发项目。
1.流量在某一时刻暴涨,然后又猛跌如何应对?
参考答案:
- 流量削峰填谷
- 在客户端与服务器加入消息队列作为缓存机制
- 接入层与各模块都采用cache增加QPS
2.redis 消息队列如何对过期信息/无效信息进行删除
参考答案:
- 添加过期时间上限
- 不同组团信息采用不同队列,当该组团满额之后删除队列
3.redis 的持久化机制?
- 参考答案:RDB和AOF
4. 为什么JAVA类加载要用双亲委派
- 实例:Object类唯一
5.怎么实现同步
- Synchronized关键字
- Volatile变量
- Lock对象
6. JAVA锁有哪几种
- Sychronized
- ReentrantLock
7. 两种锁的区别
- Synchronized 由JVM实现
- ReentrantLock 由JDK实现
6. 了解过AQS吗?
- AQS(Abstract Queue Synchronizer)队列同步器
- 由一个Valotaile变量标记状态State,以及一个CLH(同步、FIFO)队列构成
具体实现类:
- CountdownLatch: 等待多个线程完成;
- CyclicBarrier:同步屏障;
- Semaphore:控制并发线程数。
7. 场景题:给一个方法加上超时异常
- 使用AspectJ进行AOP开发
- 将方法调用进行Around切入
- 采用Future对象创建一个线程,在调用方法同时进行计时
- 若Future率先返回值则抛出超时异常
- 否则则正常调用
收集了各方面的,当前公司的,还有自己收集总结的,下面的图片截取的有pdf,有如果有需要的自取.
各大公司面试题集合:
简历模板: