Java 岗 168 道面试题:jvm+readis+mysql+spring+ 并发编程

今天在这分享目前国内公司 Java 面试常问的问题包括 JVM、常用的算法和数据结构,redis 缓存,分布式,Spring,微服务等。正所谓知己知彼,只有体系知识巩固,面对不断更新的技术才能快速掌握,同时在面试、工作中也更能脱颖而出!

一,性能优化专题:

1.tomcat 优化相关:

  1. 你怎样给 tomcat 去调优?

  2. 如何加大 tomcat 连接数

  3. tomcat 中如何禁止列目录下的文件

  4. 怎样加大 tomcat 的内存。

  5. Tomcat 有几种部署方式?

  6. Tomcat 的优化经验。

2.jvm 性能优化相关:

  1. Java 类加载过程?

  2. 描述一下 JVM 加载 Class 文件的原理机制?

  3. Java 内存分配。

  4. GC 是什么?为什么要有 GC?

  5. 简述 Java 垃圾回收机制。

  6. 如何判断一个对象是否存活?(或者 GC 对象的判定方法

  7. 垃圾回收的优点和原理。并考虑 2 种回收机制。

  8. 垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?

  9. Java 中会存在内存泄漏吗,请简单描述。

  10. 深拷贝和浅拷贝。

  11. System.gc()和 Runtime.gc()会做什么事情?

  12. finalize()方法什么时候被调用?析构函数(finalization)的目的是什么?

  13. 如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存?

  14. 什么是分布式垃圾回收(DGC)?它是如何工作的?

  15. 串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?

  16. 在 Java 中,对象什么时候可以被垃圾回收?

  17. 简述 Java 内存分配与回收策率以及 Minor GC 和 MajorGC。

  18. JVM 的永久代中会发生垃圾回收么?

  19. Java 中垃圾收集的方法有哪些?

  20. 什么是类加载器,类加载器有哪些?

  21. 类加载器双亲委派模型机制?

答案解析:

答案解析

微服务架构专题:

1.springcloud 面试专题:

  1. 什么是 SpringCloud?

  2. 使用 SpringCloud 有什么优势?

  3. 服务注册和发现是什么意思?SpringCloud 如何实现?

  4. 负载平衡的意义什么?

  5. 什么是 Hystrix?它如何实现容错?

  6. 什么是 Hystrix 断路器?我们需要它吗?

  7. 什么是 NetflixFeign?它的优点是什么?

  8. 什么是 SpringCloudBus?我们需要它吗?

2.SpringBoot 面试专题:

  1. 什么是 SpringBoot?

  2. SpringBoot 有哪些优点?

  3. 什么是 JavaConfig

  4. 如何重新加载 SpringBoot 上的更改,而无需重新启动服务器?

  5. SpringBoot 中的监视器是什么?

  6. 如何在 SpringBoot 中禁用 Actuator 端点安全性?

  7. 如何在自定义端口上运行 SpringBoot 应用程序?

  8. 什么是 YAML?

  9. 如何实现 SpringBoot 应用程序的安全性?

  10. 如何集成 SpringBoot 和 ActiveMQ?

  11. 如何使用 SpringBoot 实现分页和排序?

  12. 什么是 Swagger?你用 SpringBoot 实现了它吗?

  13. 什么是 SpringProfiles?

  14. 什么是 SpringBatch?

  15. 什么是 FreeMarker 模板?

  16. 如何使用 SpringBoot 实现异常处理?

  17. 您使用了哪些 startermaven 依赖项?

  18. 什么是 CSRF 攻击?

  19. 什么是 WebSockets?

  20. 什么是 AOP?

  21. 什么是 ApacheKafka?

  22. 我们如何监视所有 SpringBoot 微服务?

3.dubbo 面试专题:

  1. dubbo 中 zookeeper 做注册中心,如果注册中心集群都挂掉,发布者和订阅者之间还能通信么?

  2. dubbo 服务负载均衡策略?

  3. dubbo 在安全机制方面是如何解决

  4. dubbo 连接注册中心和直连的区别

答案解析

三,Redis 专题:

  1. 什么是 Redis?简述它的优缺点?

  2. Redis 与 memcached 相比有哪些优势?

  3. Redis 支持哪几种数据类型?

  4. Redis 主要消耗什么物理资源?

  5. Redis 有哪几种数据淘汰策略?

  6. Redis 官方为什么不提供 Windows 版本?

  7. 一个字符串类型的值能存储最大容量是多少?

  8. 为什么 Redis 需要把所有数据放到内存中?

  9. Redis 集群方案应该怎么做?都有哪些方案?

  10. Redis 集群方案什么情况下会导致整个集群不可用?

  11. MysqL 里有 2000w 数据,redis 中只存 20w 的数据,如何保证 redis 中的数据都是热点数据?

  12. Redis 有哪些适合的场景?

  13. Redis 支持的 Java 客户端都有哪些?官方推荐用哪个?

  14. Redis 和 Redisson 有什么关系?

  15. Jedis 与 Redisson 对比有什么优缺点?

  16. 说说 Redis 哈希槽的概念?

  17. Redis 集群的主从复制模型是怎样的?

  18. Redis 集群会有写操作丢失吗?为什么?

  19. Redis 集群之间是如何复制的?

  20. Redis 集群最大节点个数是多少?

  21. Redis 集群如何选择数据库

  22. Redis 中的管道有什么用?

  23. 怎么理解 Redis 事务?

  24. Redis 事务相关的命令有哪几个?

  25. Rediskey 的过期时间和永久有效分别怎么设置?

  26. Redis 如何做内存优化?

  27. Redis 回收进程如何工作的?

  28. 使用过 Redis 分布式锁么,它是怎么实现的?

  29. 使用过 Redis 做异步队列么,你是怎么用的?有什么缺点?

  30. 什么是缓存穿透?如何避免?什么是缓存雪崩?何如避免?

答案解析:

答案解析

四,MysqL 专题:

  1. 一张表,里面有 ID 自增主键,当 insert 了 17 条记录之后,删除了第 15,16,17 条记录,再把 MysqL 重启,再 insert 一条记录,这条记录的 ID 是 18 还是 15?

  2. MysqL 的技术特点是什么?

  3. Heap 表是什么?

  4. MysqL 服务器认端口是什么?

  5. 与 Oracle 相比,MysqL 有什么优势?

  6. 如何区分 FLOAT 和 DOUBLE?

  7. 区分 CHAR_LENGTH 和 LENGTH?

  8. 请简洁描述 MysqL 中 InnoDB 支持的四种事务隔离级别名称,以及逐级之间的区别?

  9. MysqL 中 ENUM 的用法是什么?

  10. 如何定义 REGEXP?

  11. CHAR 和 VARCHAR 的区别?

  12. 列的字符串类型可以是什么?

  13. 如何获取当前的 MysqL 版本?

  14. MysqL 中使用什么存储引擎?

  15. MysqL 驱动程序是什么?

  16. TIMESTAMP 在 UPDATECURRENT_TIMESTAMP 数据类型上做什么?

  17. 主键和候选键有什么区别?

  18. 如何使用 Unixshell 登录 MysqL

  19. myisamchk 是用来做什么的?

  20. MysqL 数据库服务器性能分析的方法命令有哪些?

  21. 如何控制 HEAP 表的最大尺寸?

  22. MyISAMStatic 和 MyISAMDynamic 有什么区别?

  23. federated 表是什么?

  24. 如果一个表有一列定义为 TIMESTAMP,将发生什么?

  25. 列设置为 AUTOINCREMENT 时,如果在表中达到最大值,会发生什么情况?

  26. 怎样才能找出最后一次插入时分配了哪个自动增量?

  27. 你怎么看到为表格定义的所有索引?

  28. LIKE 声明中的%和_是什么意思?

  29. 如何在 Unix 和 MysqL 时间戳之间进行转换?

  30. 列对比运算符是什么?

  31. 我们如何得到受查询影响的行数?

  32. MysqL 查询是否区分大小写?

  33. LIKE 和 REGEXP 操作有什么区别?

  34. BLOB 和 TEXT 有什么区别?

  35. MysqL_fetch_array 和 MysqL_fetch_object 的区别是什么?

  36. 我们如何在 MysqL 中运行批处理模式?

  37. MyISAM 表格将在哪里存储,并且还提供其存储格式?

  38. MysqL 中有哪些不同的表格?

  39. ISAM 是什么?

  40. InnoDB 是什么?

  41. MysqL 如何优化 disTINCT?

  42. 如何输入字符为十六进制数字?

  43. 如何显示前 50 行?

  44. 可以使用多少列创建索引?

  45. Now()和 CURRENT_DATE()有什么区别?

  46. 什么样的对象可以使用 CREATE 语句创建?

  47. MysqL 表中允许有多少个 TRIGGERS?

  48. 什么是非标准字符串类型?

  49. 什么是通用 sql 函数

  50. 解释访问控制列表

  51. MysqL 支持事务吗?

  52. MysqL 里记录货币用什么字段类型好

  53. MysqL 数据表在什么情况下容易损坏?

  54. MysqL 有关权限的表都有哪几个?

  55. MysqL 中有哪几种锁?

    答案解析:

答案解析

五,并发编程专题:

  1. Synchronized 用过吗,其原理是什么?

  2. 你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁?

  3. 什么是可重入性,为什么说 Synchronized 是可重入锁?

  4. JVM 对 Java 的原生锁做了哪些优化?48

  5. 为什么说 Synchronized 是非公平锁?49

  6. 什么是锁消除和锁粗化?49

  7. 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性?

  8. 乐观锁一定就是好的吗?

  9. 跟 Synchronized 相比,可重入锁 reentrantlock 其实现原理有什么不同?

  10. 那么请谈谈 AQS 框架是怎么回事儿?

  11. 请尽可能详尽地对比下 Synchronized 和 reentrantlock 的异同。

  12. reentrantlock 是如何实现可重入性的?

  13. 除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?

  14. 请谈谈 ReadWriteLock 和 StampedLock。

  15. 如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。

  16. CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?

  17. Java 线程池相关问题

  18. Java 中的线程池是如何实现的?

  19. 创建线程池的几个核心构造参数?

  20. 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?

  21. 既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中认实现好的线程池又有哪些呢?请比较它们的异同

  22. 如何在 Java 线程池中提交线程?

  23. 什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?

  24. 请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性?

  25. 既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?

  26. 请对比下 volatile 对比 Synchronized 的异同。

  27. 请谈谈 ThreadLocal 是怎么解决并发安全的?

  28. 很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?

答案解析:

 

 

答案解析

由于篇幅原因,在这就不做全部展示了,这些题我已经整理成 pdf需要的朋友请留言。

 

 

 

 

 

相关文章

显卡天梯图2024最新版,显卡是电脑进行图形处理的重要设备,...
初始化电脑时出现问题怎么办,可以使用win系统的安装介质,连...
todesk远程开机怎么设置,两台电脑要在同一局域网内,然后需...
油猴谷歌插件怎么安装,可以通过谷歌应用商店进行安装,需要...
虚拟内存这个名词想必很多人都听说过,我们在使用电脑的时候...