最新Java岗面试清单:分布式+Dubbo+线程+Redis+数据库+JVM

  1. 同步和异步有何异同,在什么情况下分别使用它们?

  2. 线程间通信,wait和notify

  3. 什么是线程饿死,什么是活锁?

  4. atomicinteger和volatile等线程安全操作的关键字的理解和使用

  5. volatile 变量是什么?volatile 变量和 atomic 变量有什么不同?

  6. 当一个线程进入一个对象的一个 synchronized 方法后,其它线程是否可进入此对象的其它方法?

  7. 简述 synchronized 和 java.util.concurrent.locks.Lock 的异同?

  8. 多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。

  9. volatile 类型变量提供什么保证?能使得一个非原子操作变成原子操作吗?

  10. 了解可重入锁的含义,以及ReentrantLock 和synchronized的区别

  11. Java创建线程之后,直接调用start()方法和run()的区别

  12. 同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么它是同步的且效率高

  13. 常用的线程池模式以及不同线程池的使用场景

  14. newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。

七、网络方面

======

  1. 为什么要三次握手

  2. 二次握手有什么问题

  3. 三次握手有哪些缺陷

  4. TCP是如何控制流量的

  5. 发送方发送频率过高造成丢包,TCP是如何解决的

  6. HTTPs为什么要用对称加密+非对称加密,相对于只使用非对称加密有什么好处

  7. 讲一下OSI网络架构

  8. HTTP在哪一层

  9. HTTP报文结构

  10. HTTP首部字段

  11. HTTPs加密在哪一层实现

  12. http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。

  13. socket通信,以及长连接,分包,连接异常断开的处理。

  14. socket通信模型的使用,AIO和NIO。

  15. socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞

八、MySQL数据库

==========

  1. 务四大特性(ACID)原子性、一致性、隔离性、持久性?

  2. 查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序?

  3. MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?

  4. MySQL的MyISAM与InnoDB两种存储引擎在,事务、锁级别,各自的适用场景?

  5. mysql 高并发环境解决方案?

  6. 事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别?

  7. MySQL B+Tree索引和Hash索引的区别?

  8. 有哪些锁(乐观锁悲观锁),select 时怎么加排它锁?

  9. sql查询语句确定创建哪种类型的索引?如何优化查询?

  10. 聚集索引和非聚集索引区别?

  11. mysql都有什么锁,死锁判定原理和具体场景,死锁怎么解决?

  12. 非关系型数据库和关系型数据库区别,优势比较?

  13. MySQL慢查询怎么解决?

  14. 数据库的读写分离、主从复制,主从复制分析的 7 个问题?

  15. 数据库崩溃时事务的恢复机制(REDO日志和UNDO日志)?

九、Redis缓存

=========

  1. redis事务相关命令有哪些?

  2. 为什么要用 redis /为什么要用缓存(高性能、高并发)

  3. 为什么要用 redis 而不用 map/guava 做缓存?

  4. redis 和 memcached 的区别

  5. 请介绍一下Redis的数据类型SortedSet(zset)以及底层实现机制?

  6. redis 常见数据结构以及使用场景分析(String、Hash、List、Set、Sorted Set)

  7. redis 设置过期时间

  8. redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)

  9. redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)

  10. redis 事务

  11. Redis 常见异常及解决方案(缓存穿透、缓存雪崩、缓存预热、缓存降级)

  12. 分布式环境下常见的应用场景(分布式锁、分布式自增 ID)

  13. Redis 集群模式(主从模式、哨兵模式、Cluster 集群模式)

  14. 如何解决 Redis 的并发竞争 Key 问题

  15. 如何保证缓存与数据库双写时的数据一致性?

十、JVM相关

=======

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

  2. java 中垃圾收集的方法有哪些?

  3. 简述 java 垃圾回收机制?

  4. GC 的两种判定方法?

  5. Minor GC 与 Full GC 分别在什么时候发生?

  6. JVM 内存分哪几个区,每个区的作用是什么?

  7. GC 收集器有哪些?CMS 收集器与 G1 收集器的特点

  8. GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?

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

  10. java 类加载过程?

  11. 简述 java 类加载机制?

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

  13. 简述 java 内存分配与回收策略以及 Minor GC 和Major GC

  14. HotSpot 虚拟机对象探秘

  15. HotSpot 垃圾收集器

十一、调优方面

=======

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

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

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

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

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

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

  7. 你怎样给 tomcat 去调优?

  8. Tomcat 的优化经验

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

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

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

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

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

  14. tomcat 有哪几种 Connector 运行模式(优化)?

  15. 内存调优

十二、设计模式

=======

  1. 21种设计模式知识要点

  2. 请列举出在 JDK 中几个常用的设计模式?

  3. 什么是设计模式?你是否在你的代码里面使用过任何设计模式?

  4. 在 Java 中,什么叫观察者设计模式(observer design pattern)?

  5. 使用工厂模式最主要的好处是什么?在哪里使用?

  6. 在 Java 中,什么时候用重载,什么时候用重写?

  7. 在 Java 中,为什么不允许从静态方法中访问非静态变量?

  8. 设计一个 ATM 机,请说出你的设计思路?

  9. 举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次

  10. 举例说明什么情况下会更倾向于使用抽象类而不是接口?

十三、算法&数据结构

==========

  1. 如何仅用递归函数和栈操作逆序一个栈?

  2. 将单向链表按某值划分成左边小、中间相等、右边大的形式

  3. 分别用递归和非递归方式实现二叉树先序、中序和后序遍历

  4. 斐波拉契系列问题的递归和动态规划

  5. 判断字符数组中是否有的字符都只出现过一次

  6. 在有序但含有空的数组中查找字符串

  7. 只用2GB内存在20亿个整数中找到出现次数最多的数

  8. 未排序数组中累加和小于或等于给定值的最长子数组长度

  9. 从5随机到7随机及其扩展

  10. 最大值减去最小值小于或等于num的子数组数量

  11. 环形单链表的约瑟夫问题

  12. 将单链表的每K个节点之间逆序

  13. 在二叉树中找到累加和为指定值的最长路径长度

  14. 判断一棵二叉树是否为搜索二叉树和完全二叉树

  15. 最长公共子序列问题

十四、并发

=====

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

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

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

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

  5. ReentrantLock 是如何实现可重入性的?

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

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

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

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

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

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

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

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

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

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

十五、操作系统/Linux

=============

  1. 死锁产生的原因

  2. 进程、线程区别,什么时候用线程

  3. 如何实现一个线程池,Java中线程池如何进行配置

  4. linux中有哪些常见的指令,进行介绍

  5. select、poll、epoll有没有了解过,讲解一下

  6. 线程切换,引申到Java阻塞➡️运行

  7. 如何分层复制/home目录到另一个目录?

  8. 什么是安装Linux所需的最小分区数量,以及如何查看系统启动信息?

  9. 如何暂停一个正在运行的进程,把其放在后台(不运行)?

  10. 什么是页面错误,它是怎么发生的?

总结

面试难免让人焦虑不安。经历过的人都懂的。但是如果你提前预测面试官要问你的问题并想出得体的回答方式,就会容易很多。

此外,都说“面试造火箭,工作拧螺丝”,那对于准备面试的朋友,你只需懂一个字:刷!

给我刷刷刷刷,使劲儿刷刷刷刷刷!今天既是来谈面试的,那就必须得来整点面试真题,这不花了我整28天,做了份“Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法等”

image

且除了单纯的刷题,也得需准备一本【JAVA进阶核心知识手册】:JVM、JAVA集合、JAVA多线程并发、JAVA基础、Spring 原理、微服务、Netty与RPC、网络、日志、Zookeeper、Kafka、RabbitMQ、Hbase、MongoDB、Cassandra、设计模式、负载均衡、数据库、一致性算法、JAVA算法、数据结构、加密算法、分布式缓存、Hadoop、Spark、Storm、YARN、机器学习、云计算,用来查漏补缺最好不过。

image

加入社区:https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0
-TSbQOS3m-1725610712228)]

且除了单纯的刷题,也得需准备一本【JAVA进阶核心知识手册】:JVM、JAVA集合、JAVA多线程并发、JAVA基础、Spring 原理、微服务、Netty与RPC、网络、日志、Zookeeper、Kafka、RabbitMQ、Hbase、MongoDB、Cassandra、设计模式、负载均衡、数据库、一致性算法、JAVA算法、数据结构、加密算法、分布式缓存、Hadoop、Spark、Storm、YARN、机器学习、云计算,用来查漏补缺最好不过。

[外链图片转存中…(img-C02QhB66-1725610712229)]

加入社区:https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值