Java 最常见的 200+ 面试题:面试必备(加上自己的一点小总结,外加无偿分享)

有急需的小伙伴可以直接下载,不墨迹(连接失效,随时评论,会更新的!!!)

链接:https://pan.baidu.com/s/1boi0nPmDxa29L2hgNg2MqQ 
提取码:li6o 

也可以支持下,用积分下载(ps:我可能也需要积分去下载一些东西,我为人人,人人为我)

https://download.csdn.net/download/yuanmomoya/11297077

适宜阅读人群

  • 需要面试的初/中/高级 java 程序员
  • 想要查漏补缺的人
  • 想要不断完善和扩充自己 java 技术栈的人
  • java 面试官

面试题模块介绍

面试题包含的内容了十九了模块:Java 基础、容器、多线程、反射、对象拷贝、Java Web 模块、异常、网络、设计模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、Mybatis、RabbitMQ、Kafka、Zookeeper、MySql、Redis、JVM 。如下图所示:
 

 

可能对于初学者不需要后面的框架和 JVM 模块的知识,读者朋友们可根据自己的情况,选择对应的模块进行阅读。 

具体面试题

一、Java 基础

1.JDK 和 JRE 有什么区别?

  • JDK:  Java  Development   Kit 的简称,Java开发包工具,提供了Java开发环境和运行环境
  • JRE:Java Runtime  Environment的简称,Java运行环境,为Java的运行提供了所需环境

具体来说JDK其实包含了JRE,同时还包含了编译Java源码的编辑器JavaC,还包含了很多Java程序的调试和分析工具。(这些工具可以在jdk下的bin目录找到)。简单来说:如果你需要运行Java程序,只需要安装JRE就可以了,如果你需要编写Java程序,需要安装JDK。

2.== 和 equals 的区别是什么?

《1.==解读

对于基本类型和引用类型==的作用是不同的:

基本类型:比较的是值是否相同

引用类型:比较的是引用是否相同

代码示例:

String x = "String";
String y = "String";
String z = new String("String");
System.out.println(x==y);  //true
System.out.println(x==z);  //false
System.out.println(x.equals(y));  //true
System.out.println(x.equals(z));  //true

代码解读:因为x和y指向同一个引用(即在堆中的地址相同),所以==也是true,而new String() 方法则重新开辟了内存空间,所以==结果为false,而equals比较的一直是值,所以结果都为true。

《2.equals解读

equals本质上就是==,只不过String和Integer等重写了equals方法,把它变成了值比较。

例子:首先来看默认情况下equals比较一个相同值的对象,代码如下:

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestEquals1 {
    public static void main(String[] args) {
        Cat c1 = new Cat("袁默默");
        Cat c2 = new Cat("袁默默");
        System.out.println(c1.equals(c2));  //false
     }
}
class Cat {
    private String name;

    public Cat(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

输出的结果出乎我们的意料,竟然是false?这是怎么回事,看了equals源码就知道了

// equals源码
public boolean equals(Object obj) {
        return (this == obj);
    }

原来equals本质上就是==。

那问题来了,两个相同值的String对象,为什么返回的是true?

String str1 = new String("袁默默");
String str2 = new String("袁默默");
System.out.println(str1.equals(str2));   //true


//String中重写了equals
 public boolean equals(Object anObject) {
        if (this == anObject) {
            return true;
        }
        if (anObject instanceof String) {
            String anotherString = (String)anObject;
            int n = value.length;
            if (n == anotherString.value.length) {
                char v1[] = value;
                char v2[] = anotherString.value;
                int i = 0;
                while (n-- != 0) {
                    if (v1[i] != v2[i])
                        return false;
                    i++;
                }
                return true;
            }
        }
        return false;
    }
 

原来是String重写了Object的equals方法,把引用比较改成了值比较

总结:== 对于基本类型来说是值比较,对于应用类型来说是比较的应用;而equals默认情况下是引用比较,只是很多类重新写了equals方法,比如String、Integer等把它变成了值比较,所以一般情况下equals比较的是值是否相等。

ps:你要知道在编写一个类的时候,可以重写Object的类的(所有类的父类)的哪些方法?

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

不对,两个对象的hashCode()相同,equals()却不一定是true

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestHashCode {
    public static void main(String[] args) {
        String str1 = "通话";
        String str2 = "重地";
        System.out.println(String.format("str1: %d | str2: %d", str1.hashCode(),str2.hashCode()));
        System.out.println(str1.equals(str2));
    }
}

/* 结果
 *str1: 1179395 | str2: 1179395
 *false
 */

看到hashCode值相等,我就有点蒙了,为什么会相等?又去看了一下源码

//原来String中的hashCode值和长度有关
public int hashCode() {
        int h = hash;
        if (h == 0 && value.length > 0) {
            char val[] = value;
            
            for (int i = 0; i < value.length; i++) {
                h = 31 * h + val[i];
            }
            hash = h;
        }
        return h;
    }

代码解读:很显然”通话“和”重地“的hashCode()相同,然而equals()则为false,因为在散列表中,hashCode()相等即两个键值对的哈希值相等,然而哈希值相等,并不一定能得出键值对相等。

4.final 在 java 中有什么作用?

final   adj. 最终的;决定性的;不可更改的

  • final修饰的类叫最终类,该类不能被继承
  • final修饰的方法不能被重写
  • final修饰的变量叫常量,常量必须初始化,初始化之后不能被修改。

5.java 中的 Math.round(-1.5) 等于多少?

等于-1;  因为在数轴上取值,中间值(0.5)向右取整,所以正0.5是往上取值,负0.5等于直接舍弃

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestMathRound {
    public static void main(String[] args) {
        System.out.println(Math.round(-1.5));
        System.out.println(Math.round(-1.51));
        System.out.println(Math.round(-1.4));
        System.out.println(Math.round(-1.6));

        System.out.println(Math.round(1.5));
        System.out.println(Math.round(1.51));
        System.out.println(Math.round(1.4));
        System.out.println(Math.round(1.6));
    }
}


/* 结果
 *-1
 *-2
 *-1
 *-2
 *2
 *2
 *1
 *2
 */

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

String不属于基础类型,基础类型有8种:byte、boolean、char、short、int、float、long、double,而String类型属于对象(引用类型)

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

操作字符串的类有:String、StringBuffer、StringBuilder

String和StringBuffer、StringBuilder的区别在于String声明的是不可变的对象,每次操作都会生成新的String对象,然后将指针指向新的String对象,而StringBuffer、StringBuilder可以在原有对象的基础上进行操作,所以经常改变字符串内容的情况下最好不要使用String。

StringBuffer ----》线程安全

StringBuilder  ----》线程不安全

StringBuffer的性能高于StringBuffer。 单线程环境下推荐使用StringBuilder,多线程环境下推荐使用StringBuffer

8.String str="i"与 String str=new String(“i”)一样吗?

不一样,因为内存得分配方式不一样。String  str = “i”的方式,Java虚拟机会将其分配到常量池中;而String  str = new String(“i”)则会被分配到堆内存中

9.如何将字符串反转?

使用StringBuilder或者StringBuffer的reverse()方法。

package com.test.java;

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestStringBufferAndStringBuilder {
    public static void main(String[] args) {
        //StringBuffer  reverse
        StringBuffer stringBuffer = new StringBuffer();
        stringBuffer.append("abcdefg");
        System.out.println(stringBuffer.reverse());  //gfedcba

        StringBuilder stringBuilder = new StringBuilder();
        stringBuilder.append("abcdefg");
        System.out.println(stringBuilder.reverse());  //gfedcba
    }
}

10.String 类的常用方法都有那些?

indexOf(): 返回指定字符的索引

charAt():  返回指定索引处的字符

replace():  字符串的替换

trim():  去除字符串两端空白

split():  分割字符串,返回一个分割后的字符串数组

getBytes():  返回字符串的byte类型数组

length(): 返回字符串的长度

toLowerCase():  将字符串转换成小写字母

toUpperCase():  将字符串转换成大写字符

subString():  截取字符串

equals():  字符串比较

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

不需要,抽象类不一定非要有抽象方法

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

普通类不能包含抽象方法,抽象类可以包含抽象方法。

抽象类不能直接实例化,普通类可以直接实例化。(实例化可以通过一些方式新建一个对象,包括new)

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

不能,定义抽象类就是让其它类继承的,如果定义为final该类就不能被继承,这样彼此就会产生矛盾,所以final不能修饰抽象类

14.接口和抽象类有什么区别?

实现:抽象类的子类使用extends来继承;接口必须使用implements来实现接口

构造函数:抽象类可以有构造函数;接口不能有。

实现数量:类可以实现很多接口;但是只能继承一个抽象类

访问修饰符:接口中的方法默认使用public修饰;抽象类中的方法可以是任意访问修饰符

15.java 中 IO 流分为几种?

按功能分: 输入流(input)、输出流(output)

按类型分: 字节流和字符流

字节流和字符流的区别是:字节流按8位传输以字节为单位输入数据,字节流按16位传输以字符为单位输入数据

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

BIO: Block IO 同步阻塞式IO,就是我们平时使用的传统IO,它的特点是模式简单使用方便,并发处理能力低

NIO: New  IO 同步非阻塞IO, 是传统IO的升级,客户端和服务端通过Channel(通道)通讯,实现了多路复用

AIO:  Asynchronous  IO 是NIO 的升级,也叫NIO2,实现了异步非阻塞IO,异步IO的操作基于事件和回调机制。

17.Files的常用方法都有哪些?

Files.exists():  检测文件路径是否存在

Files.createFile(): 创建文件

Files.createDirectory(): 创建文件夹

Files.delete():  删除一个文件或目录

Files.copy(): 复制文件

Files.move():  移动文件

Files.size():  查看文件个数

Files.read(): 读取文件

Files.write(): 写入文件

 

二、容器

18.java 容器都有哪些?

 

19.Collection 和 Collections 有什么区别?

Collection是一个集合接口,它提供了对象集合对象进行基本的通用接口方法,所有集合都是它的子类,比如List、Set等。

Collections是一个包装类,包含了很多静态方法,不能被实例化,就像一个工具类,比如提供的排序方法:Collections.sort(list)

20.List、Set、Map 之间的区别是什么?

21.HashMap 和 Hashtable 有什么区别?

存储:HashMap运行key和value为null,而Hashtable不允许。

线程安全:Hashtable是线程安全的,而HashMap是非线程安全的。

推荐使用:在Hashtable的类注释中可以看到,Hashtable是保留类不建议使用,推荐在单线程环境下使用HashMap.如果需要多线程则使用ConcurrentHashMap(分段的)

22.如何决定使用 HashMap 还是 TreeMap?

对于在Map中插入、删除、定位一个元素这类操作,HashMap是最好的选择,因为相对而言HashMap的插入会更快,但如果你要对一个key集合进行有序的遍历,那TreeMap是更好的选择。

23.说一下 HashMap 的实现原理?

24.说一下 HashSet 的实现原理?

25.ArrayList 和 LinkedList 的区别是什么?

26.如何实现数组和 List 之间的转换?

27.ArrayList 和 Vector 的区别是什么?

28.Array 和 ArrayList 有何区别?

29.在 Queue 中 poll()和 remove()有什么区别?

30.哪些集合类是线程安全的?

31.迭代器 Iterator 是什么?

32.Iterator 怎么使用?有什么特点?

33.Iterator 和 ListIterator 有什么区别?

34.怎么确保一个集合不能被修改?

三、多线程

35.并行和并发有什么区别?

36.线程和进程的区别?

37.守护线程是什么?

38.创建线程有哪几种方式?

39.说一下 runnable 和 callable 有什么区别?

40.线程有哪些状态?

41.sleep() 和 wait() 有什么区别?

42.notify()和 notifyAll()有什么区别?

43.线程的 run()和 start()有什么区别?

44.创建线程池有哪几种方式?

45.线程池都有哪些状态?

46.线程池中 submit()和 execute()方法有什么区别?

47.在 java 程序中怎么保证多线程的运行安全?

48.多线程锁的升级原理是什么?

49.什么是死锁?

50.怎么防止死锁?

51.ThreadLocal 是什么?有哪些使用场景?

52.说一下 synchronized 底层实现原理?

53.synchronized 和 volatile 的区别是什么?

54.synchronized 和 Lock 有什么区别?

55.synchronized 和 ReentrantLock 区别是什么?

56.说一下 atomic 的原理?

四、反射

57.什么是反射?

58.什么是 java 序列化?什么情况下需要序列化?

59.动态代理是什么?有哪些应用?

60.怎么实现动态代理?

五、对象拷贝

61.为什么要使用克隆?

62.如何实现对象克隆?

63.深拷贝和浅拷贝区别是什么?

六、Java Web

64.jsp 和 servlet 有什么区别?

65.jsp 有哪些内置对象?作用分别是什么?

66.说一下 jsp 的 4 种作用域?

67.session 和 cookie 有什么区别?

68.说一下 session 的工作原理?

69.如果客户端禁止 cookie 能实现 session 还能用吗?

70.spring mvc 和 struts 的区别是什么?

71.如何避免 sql 注入?

72.什么是 XSS 攻击,如何避免?

73.什么是 CSRF 攻击,如何避免?

七、异常

74.throw 和 throws 的区别?

75.final、finally、finalize 有什么区别?

76.try-catch-finally 中哪个部分可以省略?

77.try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?

78.常见的异常类有哪些?

八、网络

79.http 响应码 301 和 302 代表的是什么?有什么区别?

80.forward 和 redirect 的区别?

81.简述 tcp 和 udp的区别?

82.tcp 为什么要三次握手,两次不行吗?为什么?

83.说一下 tcp 粘包是怎么产生的?

84.OSI 的七层模型都有哪些?

85.get 和 post 请求有哪些区别?

86.如何实现跨域?

87.说一下 JSONP 实现原理?

九、设计模式

88.说一下你熟悉的设计模式?

89.简单工厂和抽象工厂有什么区别?

十、Spring/Spring MVC

90.为什么要使用 spring?

91.解释一下什么是 aop?

92.解释一下什么是 ioc?

93.spring 有哪些主要模块?

94.spring 常用的注入方式有哪些?

95.spring 中的 bean 是线程安全的吗?

96.spring 支持几种 bean 的作用域?

97.spring 自动装配 bean 有哪些方式?

98.spring 事务实现方式有哪些?

99.说一下 spring 的事务隔离?

100.说一下 spring mvc 运行流程?

101.spring mvc 有哪些组件?

102.@RequestMapping 的作用是什么?

103.@Autowired 的作用是什么?

十一、Spring Boot/Spring Cloud

104.什么是 spring boot?

105.为什么要用 spring boot?

106.spring boot 核心配置文件是什么?

107.spring boot 配置文件有哪几种类型?它们有什么区别?

108.spring boot 有哪些方式可以实现热部署?

109.jpa 和 hibernate 有什么区别?

110.什么是 spring cloud?

111.spring cloud 断路器的作用是什么?

112.spring cloud 的核心组件有哪些?

十二、Hibernate

113.为什么要使用 hibernate?

114.什么是 ORM 框架?

115.hibernate 中如何在控制台查看打印的 sql 语句?

116.hibernate 有几种查询方式?

117.hibernate 实体类可以被定义为 final 吗?

118.在 hibernate 中使用 Integer 和 int 做映射有什么区别?

119.hibernate 是如何工作的?

120.get()和 load()的区别?

121.说一下 hibernate 的缓存机制?

122.hibernate 对象有哪些状态?

123.在 hibernate 中 getCurrentSession 和 openSession 的区别是什么?

124.hibernate 实体类必须要有无参构造函数吗?为什么?

十三、Mybatis

125.mybatis 中 #{}和 ${}的区别是什么?

126.mybatis 有几种分页方式?

127.RowBounds 是一次性查询全部结果吗?为什么?

128.mybatis 逻辑分页和物理分页的区别是什么?

129.mybatis 是否支持延迟加载?延迟加载的原理是什么?

130.说一下 mybatis 的一级缓存和二级缓存?

131.mybatis 和 hibernate 的区别有哪些?

132.mybatis 有哪些执行器(Executor)?

133.mybatis 分页插件的实现原理是什么?

134.mybatis 如何编写一个自定义插件?

十四、RabbitMQ

135.rabbitmq 的使用场景有哪些?

136.rabbitmq 有哪些重要的角色?

137.rabbitmq 有哪些重要的组件?

138.rabbitmq 中 vhost 的作用是什么?

139.rabbitmq 的消息是怎么发送的?

140.rabbitmq 怎么保证消息的稳定性?

141.rabbitmq 怎么避免消息丢失?

142.要保证消息持久化成功的条件有哪些?

143.rabbitmq 持久化有什么缺点?

144.rabbitmq 有几种广播类型?

145.rabbitmq 怎么实现延迟消息队列?

146.rabbitmq 集群有什么用?

147.rabbitmq 节点的类型有哪些?

148.rabbitmq 集群搭建需要注意哪些问题?

149.rabbitmq 每个节点是其他节点的完整拷贝吗?为什么?

150.rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况?

151.rabbitmq 对集群节点停止顺序有要求吗?

十五、Kafka

152.kafka 可以脱离 zookeeper 单独使用吗?为什么?

153.kafka 有几种数据保留的策略?

154.kafka 同时设置了 7 天和 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?

155.什么情况会导致 kafka 运行变慢?

156.使用 kafka 集群需要注意什么?

十六、Zookeeper

157.zookeeper 是什么?

158.zookeeper 都有哪些功能?

159.zookeeper 有几种部署模式?

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

161.集群中为什么要有主节点?

162.集群中有 3 台服务器,其中一个节点宕机,这个时候 zookeeper 还可以使用吗?

163.说一下 zookeeper 的通知机制?

十七、MySql

164.数据库的三范式是什么?

165.一张自增表里面总共有 7 条数据,删除了最后 2 条数据,重启 mysql 数据库,又插入了一条数据,此时 id 是几?

166.如何获取当前数据库版本?

167.说一下 ACID 是什么?

168.char 和 varchar 的区别是什么?

169.float 和 double 的区别是什么?

170.mysql 的内连接、左连接、右连接有什么区别?

171.mysql 索引是怎么实现的?

172.怎么验证 mysql 的索引是否满足需求?

173.说一下数据库的事务隔离?

174.说一下 mysql 常用的引擎?

175.说一下 mysql 的行锁和表锁?

176.说一下乐观锁和悲观锁?

177.mysql 问题排查都有哪些手段?

178.如何做 mysql 的性能优化?

十八、Redis

179.redis 是什么?都有哪些使用场景?

180.redis 有哪些功能?

181.redis 和 memecache 有什么区别?

182.redis 为什么是单线程的?

183.什么是缓存穿透?怎么解决?

184.redis 支持的数据类型有哪些?

185.redis 支持的 java 客户端都有哪些?

186.jedis 和 redisson 有哪些区别?

187.怎么保证缓存和数据库数据的一致性?

188.redis 持久化有几种方式?

189.redis 怎么实现分布式锁?

190.redis 分布式锁有什么缺陷?

191.redis 如何做内存优化?

192.redis 淘汰策略有哪些?

193.redis 常见的性能问题有哪些?该如何解决?

十九、JVM

194.说一下 jvm 的主要组成部分?及其作用?

195.说一下 jvm 运行时数据区?

196.说一下堆栈的区别?

197.队列和栈是什么?有什么区别?

198.什么是双亲委派模型?

199.说一下类加载的执行过程?

200.怎么判断对象是否可以被回收?

201.java 中都有哪些引用类型?

202.说一下 jvm 有哪些垃圾回收算法?

203.说一下 jvm 有哪些垃圾回收器?

204.详细介绍一下 CMS 垃圾回收器?

205.新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么区别?

206.简述分代垃圾回收器是怎么工作的?

207.说一下 jvm 调优的工具?

208.常用的 jvm 调优的参数都有哪些?

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章