java面试题整理

一、Java 基础

1.JDK 和 JRE 有什么区别?

JRE(Java Runtime environment),Java运行环境,包含了Java虚拟机和核心类库。

JDK(Java Development Kit),Java开发工具包。包含了jre,一些工具(javac/javap)和基本类库。

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

==做值比较,当比较的是基本数据类型,直接比较值,当比较的是引用类型,比较的是在内存中的首地址。

equals 比较的是对象的内容或者成员属性是否相同,equals是Object类的方法,方法如果不重写,依然是使用==作比较,因此要想使用equals() 必须重写。

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

hashCode 的常规协定是:

  • 在 Java 应用程序执行期间,在对同一对象多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是将对象进行 equals 比较时所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
  • 如果根据 equals(Object) 方法,两个对象是相等的,那么对这两个对象中的每个对象调用 hashCode 方法都必须生成相同的整数结果。
  • 如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么对这两个对象中的任一对象上调用 hashCode 方法 要求一定生成不同的整数结果。但是,程序员应该意识到,为不相等的对象生成不同整数结果可以提高哈希表的性能。

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

final是java的关键词。

修饰类,类不可变,不可被继承,类中的方法不能被重写。

修饰方法,方法不能被重写。

修饰变量,基本数据类型,值不可变,引用类型引用的实例的地址不可变。

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

Math.round(x)方法会使x=x+0.5 然后对 x 四舍五入。

Math.floor(x)向下取整。

Math.ceil(x) 向上取整。

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

不属于 八大基本数据类型 byte short int long float double char boolean

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

String StringBuffer StringBuilder

String 是内容不可变得,内部使用了一个final修饰的字符数组,字符串的拼接会产生新的对象。

StringBuffer 可变变量 ,内部使用了可变的字符数组,有append方法,对于字符串的拼接,不会产生新的字符串对象,内部的方法使用了synchronized修饰,是线程安全的,但是效率较低。

StringBuffer 可变变量 ,内部使用了可变的字符数组,有append方法,对于字符串的拼接,不会产生新的字符串对象,是线程不安全的,效率较高。

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

9.如何将字符串反转?

把字符串转换成字符数组倒叙拼接然后返回值。

public static String reverse3(String s) {
  char[] array = s.toCharArray();
  String reverse = "";
  for (int i = array.length - 1; i >= 0; i--)
   reverse += array[i];
  return reverse;
}

 调用StringBuffer中的reverse方法

public static String reverse4(String s) {
  return new StringBuffer(s).reverse().toString();
 }

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

charAt() 返回某个位置的字符。lenth() 返回字符串的长度。subString() 截取子串,compareTo() 比较两个字符串。

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

不必须,但是有抽象方法一定是抽象类。

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

普通类可以实例化对象,抽象类不可以。

抽象类可以有抽象方法,使用abstract修饰,普通类的方法必须有方法体。

抽象类的子类如果不是抽象类,必须实现所有抽象方法。

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

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

15.java 中 IO 流分为几种?

按操作的类型分:字节流和字符流

按流向:输出流和输入流

按操作是是否是原数据:节点流和处理流

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

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

二、容器

18.java 容器都有哪些?

19.Collection 和 Collections 有什么区别?

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

21.HashMap 和 Hashtable 有什么区别?

22.如何决定使用 HashMap 还是 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 有什么区别?

ListIterator 有add方法,可以向集合中添加元素。

ListIterator 存在hasprevious()和previous()方法,可以实现逆向的遍历。

listIterator存在nextIndex()previousIndex()方法,获得下标值。

listIterator 可以对集合的内容进行修改,Iterator不可以。

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

Collections提供的方法可以将集合变为内容不可变的集合。

        Collections.unmodifiableList(List<? extends T> list);
        Collections.unmodifiableCollection(Collection<? extends T> c);
        Collections.unmodifiableMap(Map<? extends K, ? extends V> m);

三、多线程

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

并行:多个cpu,多个线程同时并行执行。

并发:单个cpu,多个线程抢占时间片串行执行,时间非常短。

36.线程和进程的区别?

进程:具有某一功能的程序在数据集合上动态的执行,是系统资源分配的基本单位,对于一个进程来说数据时私有的。

线程:是轻量化的进程,是程序调度的最小单位,一个进程包括一个或者多个线程,在一个进程中的线程,共享进程的数据。

37.守护线程是什么?

守护线程是服务于用户线程的一类线程,当虚拟机中没有用户线程时,守护线程也将消失,例如垃圾回收线程就是守护线程,专门用来回收用户线程生命周期中产生的对象垃圾。

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

1. 继承Thread接口,重写run方法。2. 实现Runnable接口,实现run方法。 3. 实现Callable接口,重写call方法。 4. 使用线程池,执行execut或者submit方法。

39.说一下Runnable 和 Callable 有什么区别?

都是创建线程的方式。1. Runnable的线程体是run方法,Callable的线程体是call方法。2.Runnable的线程不能返回执行结果,Callable可以返回线程执行成功时的结果。4. call方法可以抛出异常,run方法不能抛出异常。

40.线程有哪些状态?

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

sleep()是Thread的静态方法,wait是Object的方法。

sleep调用时,是将当前线程睡眠一定的时间,能够自动唤醒,wait方法是使当前线程进入等待队列,需要程序去手动使用notify或者notifyAll唤醒。

sleep方法会释放cpu资源,wait方法需要释放锁资源。

wait方法的使用需要在拿到锁的情况下才能使用。

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

notify随机唤醒对象等待池的一个线程,notifyAll换新对象等待池的所有的对象。

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

run方法是线程体的方法,start方法是让新建线程从新建状态进入可执行状态。可执行状态的线程拿到cup的时间片将会自动调用run方法。

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

Executors.newFixedThreadPool() 创建固定核心线程数量的线程池。

Executors.newSingleThreadExecutorl() 创建一个只有一个线程的线程池。

Executors.newCacheThreadPool() 创建实际任务数量变化的线程池。

Executors.newScheduledThreadPool() 创建一个固定线程数量的线程池,支持定时及周期性任务执行。

Executors.newWorkStealingPool() 创建一个可以并行执行的任务可窃取的线程池。

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

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

submit的参数可以是Runnabe和Callable类型的,而execute参数只能是Runnable类型的。

submit方法可以有返回值,返回值为Futrue类型,可以通过Futrue类型的实例得到call方法的返回值,execute没有返回值。

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

 

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

https://blog.youkuaiyun.com/IPI715718/article/details/90243723

49.什么是死锁?

两个及两个以上的线程在执行的过程中竞争资源而出现的阻塞现象,如果没有外力作用,将会持续下去。

死锁产生的条件:互斥条件,不可剥夺,请求保持,循环条件。

50.怎么防止死锁?

https://blog.youkuaiyun.com/IPI715718/article/details/103276258

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

ThreadLocal 是一种拿空间换时间的保证线程安全的措施。看关键源码

public T get() {
        Thread t = Thread.currentThread();
        ThreadLocalMap map = getMap(t);
        if (map != null) {
            ThreadLocalMap.Entry e = map.getEntry(this);
            if (e != null) {
                @SuppressWarnings("unchecked")
                T result = (T)e.value;
                return result;
            }
        }
        return setInitialValue();
}

public void set(T value) {
    Thread t = Thread.currentThread();
    ThreadLocalMap map = getMap(t);
        if (map != null)
            map.set(this, value);
        else
            createMap(t, value);
    }

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

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

synchronized 能够保证原子性,可见性,有序性,volatile 只能保证 可见性,有序性。

54.synchronized 和 Lock 有什么区别?

55.synchronized 和 ReentrantLock 区别是什么?

1. synchronized是java的关键字, ReentrantLock 是类。

2. synchronized会自动释放锁,ReentrantLock需要手动释放。

3. ReentrantLock比synchronized使用灵活。

4. ReentrantLock可以加锁时可以显示等待和中断,synchronized只能继续阻塞。

56.说一下 atomic 的原理?

atomic是原子类得包,原子类得实现的底层原理是CAS(compare and swap)操作,中文叫做比较交换。在对某个变量做修改操作时,Unsafe的native方法需要四个值变对象本身,偏移量,期望值,新值,根据引用和偏移量取出主内存中的值,判断如果期望值与内存中的值相等,则直接修改内存值为为新的值。

四、反射

57.什么是Java反射?

Java 反射机制是在运行状态中,对于任意一个类,都能够获得这个类的所有属性和方法,对于任意一个对象都能够调用它的任意一个属性和方法。这种在运行时动态的获取信息以及动态调用对象的方法的功能称为Java 的反射机制。

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

java序列化是将java对象转化为二进制流的形式的过程叫做序列化。 

需要将对象存储,网络传输时需要将对象序列化。

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

动态代理是在程序运行的过程中运用java反射生成代理对象,对目标对象扩展和调用。

应用:spring的aop,

60.怎么实现动态代理?

 

五、对象拷贝

61.为什么要使用克隆?

62.如何实现对象克隆?

浅克隆:实现Cloneable接口 并重写clone()方法。

深克隆:可以使用序列化进行克隆。

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

浅拷贝:对于基本类型的变量,直接复制一份副本传递给新对象,引用类型的变量,复制一份引用给新对象。

深拷贝:对于基本类型的变量,直接复制一份副本传递给新对象,引用类型会将引用的实例对象复制一份,并将引用返回给新对象。

六、Java Web

64.jsp 和 servlet 有什么区别?

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

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

page 当前页面有效,当推出了当前页面即失效。

request 对当前一次请求有效,客户端发送请求,服务去处理请求,服务器返回响应,一个完整的http请求有效。

session 作用域,当我们向服务器发送第一个请求开始,只要页面不关闭,或者会话未过期(默认30分钟),或者未调用HttpSession的invalidate()方法,接下来的操作都属于同一次会话的范畴。

题外话:这里解释一下页面不关闭和页面关闭,当页面或者浏览器关闭的时候session并没有过期,只是存放着SESSIONID的cookie过期了,就无法通过SESSIONID找到原来的session了,30分钟后,session会自动过期失效,当再次访问时,服务器会重新生成一个session,并返回SESSIONID写入客户端的cookie中。

application作用域 是最广的,是整个web应用的全局变量,对每一个页面和每一个servlet都是有效的,服务器关闭齐全失效。

67.session 和 cookie 有什么区别?

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

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

能,可以对url重写,将jsessionid拼接到url上。

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

71.如何避免 sql 注入?

sql注入是指通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。

jdbc使用preparestatement,mybatis使用# 传入条件,都会使用预编译功能,将条件参数set进去。

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

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

七、异常

74.throw 和 throws 的区别?

throw 抛出一个异常的实例,如果throw抛出的是运行时异常实例,该异常可以不立即捕获,可以交给调用者去捕获并处理异常,

如果抛出的是检查性异常实例,需要立即捕获并且处理。

throws 用来声明方法可能发生的异常,调用者需要预处理该异常。

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

final是java关键字,可以用来修饰类,方法,变量。用来修饰类,类不能被继承,方法自然不能被重写。修饰方法,方法不能被重写。修饰变量,如果修饰的基本类型的变量,则值不能被改变,如果修饰的是引用变量,则引用的对象不能被改变。

finally是配合try catch使用的关键字,是无论如何都要执行的代码块。

finalize 是对象在即将被垃圾回收之前执行的方法,用来处理后续的事情,后序事情例如关闭一些资源等,也有可能执行完该方法后与引用连扯上关系,将不被垃圾回收。

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

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

会执行

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

八、网络

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

80.forward 和 redirect 的区别?

forward是转发,是服务器的动作,此时浏览器的url不会改变,request域中依然有效。

redirect是重定向是浏览器客户端的动作,url会改变,并且重新从浏览器发起请求,原来的request域会失效,会产生新的request。

81.简述 tcp 和 udp的区别?

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

不行,是为了防止已经失效的请求到服务器,导致资源浪费。

假如两次握手,A发起的连接请求由于网络延迟等原因,被认为丢包,重新发送请求并完成通信,此时网络延迟导致的请求再一次请求到B,B确认请求然后建立连接,此时A没有要发送的数据,也不会理睬B,所以导致连接资源的浪费。

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

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

从下到上 物理层 数据链路层 网络层 传输层 会话层 表示层 应用程。

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

86.如何实现跨域?

87.说一下 JSONP 实现原理?

九、设计模式

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

工厂模式:简单工厂模式、工厂方法模式、抽象工厂模式。

单例模式:饿汉式、懒汉式、双重检验模式、静态内部类,枚举类。

89.简单工厂和抽象工厂有什么区别?
关注点不同,简单工厂关注于生产某种商品,例如生产车 简单工厂只关注生产宝马车,奔驰车还是奥迪车

抽象工厂关注与生产某产品族的产品,我是生产宝马五系,三系还是七系。

十、Spring/Spring MVC

90.为什么要使用 spring?

91.解释一下什么是 aop?

面向切面

92.解释一下什么是 ioc?

ioc控制反转,是对象创建权利的反转,将对象的创建,销毁,管理交由spring容器来管理,简单来说就是 new一个对象不需要客户端new了,而是由spring利用工厂模式和java反射来完成。

93.spring 有哪些主要模块?

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

setter/getter方式,constructor方式,注解注入,工厂方法注入。

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

不是线程安全的,可以使用原型模式

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

Singleton单例,prototype原型,request,session,globlesession。

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

no,bytype,byname,byconstructor,default。

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

声明式事务(xml和注解),编程式。

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

五种事务隔离界别

1.DEFAULT 所使用数据库默认的隔离级别

2.READ_UNCOMMIT 读未提交 会出现脏读 不可重复读 幻读问题

3.READ_COMMITED 读已提交 能避免脏读问题 

4.REPEATABLE_READ 可重复读 能够避免脏读 不可重复读问题

5.SERIALIZABLE 事务序列化执行

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

浏览器请求到前端控制器,前端控制器请求处理器映射器,处理器映射器根据url解析出uri,找到匹配的处理器,并返回处理器给前端控制器,前端控制器请求处理器适配器,处理器适配器执行处理器方法,处理器返回modelAndView给处理器适配器,处理器适配器返回ModelAndView给前端控制器,前端控制器请求视图解析器,视图解析器解析ModelAndView,返回视图给前端控制器,前端控制器返回视图到浏览器。

101.spring mvc 有哪些组件?

前端控制器,处理器映射器,处理器适配器,处理器,视图解析器。

102.@RequestMapping 的作用是什么?

将处理器与url完成映射。

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 是几?

8

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

167.说一下 ACID 是什么?

数据库事务的原子性、一致性、隔离性、持久性。

原子性:指对数据库的一个或者多个操作要么全部完成,要么全部失败。

一致性:是指在对数据库的操作前后数据都处于一致性状态,不存在中间状态。

隔离性:事务与事务之间在执行的过程中互不影响。

持久性:事务一旦提交,变化将是永久性的。

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

char是定长的,varchar是变长的。

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

170.mysql 的内连接、左连接、右连接有什么区别?
内连接显示两张表中符合连接条件的数据。

左连接显示左表的所有的内容和右表的与之匹配的内容,右表不匹配的显示为空。

右连接显示右表的所有的内容和左表的与之匹配的内容,左表不匹配的显示为空。

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

索引是一种能提高检索效率的数据结构。

索引有两种数据结构 B-树和Hash结构。Innodb引擎和Mylsam引擎支持B-树索引,memory引擎支持Hash结构索引。

什么是B-树,B-树是一种多路查找树,每个结点包含多个关键字,非叶子结点的关键字会出现在子节点中,非叶子结点不包含其他信息,只起到索引的作用,叶子结点之间通过链表顺序连接。

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

explain 查看索引的使用情况

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

四种事务隔离级别

read_uncommit 读未提交 会存在数据丢失,脏读,不可重复读,幻读的问题。

实现原理:修改数据时加排它锁,修改完立即释放。读数据时不加锁。

read_commmited 读已提交 避免数据丢失 脏读问题,但还是存在不可重复读的问题。

修改时加排它锁,事务提交或者回滚后解锁,读数据时加共享锁,读完立即释放。

repeatable_read 可重复读 仍然存在幻读问题。

修改时加排它锁,事务提交或者回滚后解锁,读数据时加共享锁,事务结束后释放锁。

serializable 序列化 事务序列执行 避免所有问题 但是效率低。

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

Innodb支持行锁,页锁,支持事务,Mylsam不支持行锁,页锁,支持表锁,支持事务,memory。

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 调优的参数都有哪些?

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值