-
对象的相等与指向他们的引用相等,两者有什么不同?
-
重载和重写的区别?
-
在一个静态方法内调用一个非静态成员为什么是非法的?
-
简述线程,程序、进程的基本概念。以及他们之间关系是什么
-
什么是方法的返回值?返回值在类的方法里的作用是什么?
-
一个类的构造方法的作用是什么 若一个类没有声明构造方法,该程序能正确执行吗 ?为什么?
-
Java 面向对象编程三大特性: 封装 继承 多态
-
Java 序列化中如果有些字段不想进行序列化 怎么办?
-
在调用子类构造方法之前会先调用父类没有参数的构造方法,其目的是?
-
线程有哪些基本状态?
-
创建一个对象用什么运算符?对象实体与对象引用有何不同?
-
成员变量与局部变量的区别有哪些?
二、Java中级
========
-
Spring的AOP和IOC是什么?使用场景有哪些?Spring事务,事务的属性,数据库隔离级别
-
Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?
-
SpringCould组件有哪些,它们的作用是什么?微服务的CAP是什么?BASE是什么?
-
HashMap底层实现原理,红黑树,B+树,B树的结构原理,CAS(比较与交换)实现原理
-
Redis支持的数据类型以及使用场景,持久化,哨兵机制,缓存击穿,缓存穿透
-
线程是什么,有几种实现方式,它们之间的区别是什么,线程池实现原理,JUC并发包
-
安全性问题(数据篡改(拿到别人的URL,篡改数据(金额)发送给系统))
-
索引使用的限制条件,sql优化有哪些,数据同步问题(缓存,数据库数据同步)
-
分布式事务
-
堆溢出,栈溢出的出现场景以及解决方案
-
悲观锁,乐观锁,读写锁,行锁,表锁,自旋锁,死锁,分布式锁,线程同步锁,公平锁,非公平锁分别是什么?
-
初始化Bean对象有几个步骤,它的生命周期
-
JVM内存模型,算法,垃圾回收器,调优,类加载机制(双亲委派),创建一个对象,这个对象在内存中是怎么分配的?
-
Dubbo的运行原理,与SpringCould相比它为什么效率要高一些,Zookeeper底层原理
-
说出几种MQ之间的区别,以及为什么使用这种MQ,消息重复发送(幂等性),消息发送失败,消息掉包,长时间收不到消息,发送的消息太大造成接收不成功
三、Java高级
========
-
为什么使用消息队列?消息队列有什么优点和缺点?Kafka、ActiveMQ、RabbitMQ、RocketMQ 都有什么优点和缺点?
-
如何保证消息不被重复消费?或者说,如何保证消息消费的幂等性?
-
如何解决消息队列的延时以及过期失效问题?消息队列满了以后该怎么处理?有几百万消息持续积压几小时,说说怎么解决?
-
redis 集群模式的工作原理能说一下么?在集群模式下,redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗?
-
了解什么是 redis 的雪崩、穿透和击穿?redis 崩溃之后会怎么样?系统该如何应对这种情况?如何处理 redis 的穿透?
-
为什么要分库分表(设计高并发系统的时候,数据库层面该如何设计)?用过哪些分库分表中间件?不同的分库分表中间件都有什么优点和缺点?你们具体是如何对数据库如何进行垂直拆分或水平拆分的?
-
有没有做 MySQL 读写分离?如何实现 MySQL 的读写分离?MySQL 主从复制原理的是啥?如何解决MySQL 主从同步的延时问题?
-
说一下的 dubbo 的工作原理?注册中心挂了可以继续通信吗?说说一次 rpc 请求的流程?
-
如何基于 dubbo 进行服务治理、服务降级、失败重试以及超时重试?
-
集群部署时的分布式 session 如何实现?
-
服务注册和发现是什么意思?Spring Cloud 如何实现?
-
一般实现分布式锁都有哪些方式?使用 redis 如何设计分
-
布式锁?使用 zk 来设计分布式锁可以吗?这两种分布式锁的实现方式哪种效率比较高?
-
dubbo 的 spi 思想是什么?
-
如何设计可以动态扩容缩容的分库分表方案?
四、分布式
=====
-
ActiveMQ 中的消息重发时间间隔和重发次数吗?
-
Kafka 创建 Topic 是如何将分区放置到不同的 Broker 中
-
Kafka 判断一个节点是否还活着有哪两个条件?
-
Kafka 消息是采用 Pull 模式,还是 Push 模式?
-
memcached 和服务器的 local cache(比如 PHP 的 APC、mmap 文件等)相比,有什么优缺点?
-
我需要把 memcached 中的 item 批量导出导入,怎么办?
-
memcached 的多线程是什么?如何使用它们?
-
MongoDB 在 A:{B,C}上建立索引,查询 A:{B,C}和 A:{C,B}都会使用索引吗?
-
MongoDB 支持存储过程吗?如果支持的话,怎么用?
-
如何理解 MongoDB 中的 GridFS 机制,MongoDB 为何使用 GridFS 来存储文件?
-
在 Nginx 中,如何使用未定义的服务器名称来阻止处理请求?
-
RabbitMQ 上的一个 queue 中存放的 message 是否有数量限制?
-
若 cluster 中拥有某个 queue 的 owner node 失效了,且该 queue 被声明具有durable 属性,是否能够成功从其他 node 上重新声明该 queue ?
-
为什么说保证 message 被可靠持久化的条件是 queue 和 exchange 具有durable 属性,同时 message 具有 persistent 属性才行?
-
为什么用缓存,用过哪些缓存,redis和memcache的区别?
五、Spring架构
==========
-
Spring Boot、Spring MVC 和 Spring 有什么区别?
-
BeanFactory 和 ApplicationContext 有什么区别?
-
什么是基于Java的Spring注解配置? 给一些注解的例子.
-
请解释 Spring Bean 的生命周期?
-
Spring 框架中的单例 Beans 是线程安全的么?
-
SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决?
-
SpringMVC 怎么样设定重定向和转发的?
-
当一个方法向 AJAX 返回特殊对象,比如 Object,List 等,需要做什么处理?
-
SpringMvc 用什么对象从后台向前台传递数据的?
-
服务注册和发现是什么意思?Spring Cloud 如何实现?
-
使用 Spring Cloud 有什么优势?
-
什么是 Hystrix 断路器?我们需要它吗?
-
什么是 Spring Cloud Bus?我们需要它吗?
-
如何实现 Spring Boot 应用程序的安全性?
-
Spring Boot 配置的默认 H2 数据库的名字是上面?为什么默认的数据库名字是 testdb?
六、线程问题
======
-
stop() 和 suspend() 方法为何不推荐使用?
-
同步和异步有何异同,在什么情况下分别使用它们?
-
线程间通信,wait和notify
-
什么是线程饿死,什么是活锁?
-
atomicinteger和volatile等线程安全操作的关键字的理解和使用
-
volatile 变量是什么?volatile 变量和 atomic 变量有什么不同?
-
当一个线程进入一个对象的一个 synchronized 方法后,其它线程是否可进入此对象的其它方法?
-
简述 synchronized 和 java.util.concurrent.locks.Lock 的异同?
-
多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。
-
volatile 类型变量提供什么保证?能使得一个非原子操作变成原子操作吗?
-
了解可重入锁的含义,以及ReentrantLock 和synchronized的区别
-
Java创建线程之后,直接调用start()方法和run()的区别
-
同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么它是同步的且效率高
-
常用的线程池模式以及不同线程池的使用场景
-
newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。
七、网络方面
======
-
为什么要三次握手
-
二次握手有什么问题
-
三次握手有哪些缺陷
-
TCP是如何控制流量的
-
发送方发送频率过高造成丢包,TCP是如何解决的
-
HTTPs为什么要用对称加密+非对称加密,相对于只使用非对称加密有什么好处
-
讲一下OSI网络架构
-
HTTP在哪一层
-
HTTP报文结构
-
HTTP首部字段
-
HTTPs加密在哪一层实现
-
http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。
-
socket通信,以及长连接,分包,连接异常断开的处理。
-
socket通信模型的使用,AIO和NIO。
-
socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞
八、MySQL数据库
==========
-
务四大特性(ACID)原子性、一致性、隔离性、持久性?
-
查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序?
-
MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?
-
MySQL的MyISAM与InnoDB两种存储引擎在,事务、锁级别,各自的适用场景?
-
mysql 高并发环境解决方案?
-
事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别?
-
MySQL B+Tree索引和Hash索引的区别?
-
有哪些锁(乐观锁悲观锁),select 时怎么加排它锁?
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
写在最后
学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!
最后再分享的一些BATJ等大厂20、21年的面试题,把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
Mybatis面试专题
MySQL面试专题
并发编程面试专题
写在最后
学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!
最后再分享的一些BATJ等大厂20、21年的面试题,把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
[外链图片转存中…(img-Nu8JLUoH-1711725151523)]
Mybatis面试专题
[外链图片转存中…(img-ZyxRNIbT-1711725151523)]
MySQL面试专题
[外链图片转存中…(img-7QE9EfYm-1711725151524)]
并发编程面试专题