BATJ Java(1000题)高频面试题:MyBatis +并发编程+分布式+redis等
本文收集整理了各大厂常见面试题N道,你想要的这里都有内容涵盖:Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQL、Spring、Spring Boot、Spring Cloud、RabbitMQ、Kafka、Linux 等技术栈,希望大家都能找到适合自己的公司,开开心心的撸代码。
目录
由于题量较多,篇幅的限制,文章中的面试题分享没有全部附上详细的解析,但是整理成了一份详细的PDF文档可分享给大家,文末获取免费领取方式
MyBatis 面试题(截取部分)
1、什么是 Mybatis?
2、Mybaits 的优点
3、MyBatis 框架的缺点
4、MyBatis 框架适用场合
5、MyBatis 与 Hibernate 有哪些不同
6、#{}和${}的区别是什么
7、当实体类中的属性名和表中的字段名不一样 ,怎么办 ?
8、 模糊查询 like 语句该怎么写?
9、通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问, 这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时, 方法能重载吗?
10、Mybatis 是如何进行分页的?分页插件的原理是什么?
11、Mybatis 是如何将 sql 执行结果封装为目标对象并返回的?都有哪些映射形式?
12、如何执行批量插入?
13、如何获取自动生成的(主)键值?
14、在 mapper 中如何传递多个参数?
15、Mybatis 动态 sql 有什么用?执行原理?有哪些动态 sql?
16、Xml 映射文件中,除了常见的 select|insert|updae|delete 标签之外,还有哪些标签?
18、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?
19、 一对一、一对多的关联查询 ?
20、MyBatis 实现一对一有几种方式?具体怎么操作的?
ZooKeeper 面试题(截取部分)
ZooKeeper 面试题?
ZooKeeper 提供了什么?
Zookeeper 文件系统
ZAB 协议?
四种类型的数据节点 Znode
Zookeeper Watcher 机制 -- 数据变更通知
客户端注册 Watcher 实现
服务端处理 Watcher 实现
- 客户端回调 Watcher
10.ACL 权限控制机制
Dubbo 面试题(截取部分)
1、为什么要用 Dubbo?
2、Dubbo 的整体架构设计有哪些分层?
3、默认使用的是什么通信框架,还有别的选择吗?
4、服务调用是阻塞的吗?
5、一般使用什么注册中心?还有别的选择吗?
6、默认使用什么序列化框架,你知道的还有哪些?
7、服务提供者能实现失效踢出是什么原理?
8、服务上线怎么不影响旧版本?
9、如何解决服务调用链过长的问题?
10、说说核心的配置有哪些?
Elasticsearch 面试题(截取部分)
1、elasticsearch 了解多少,说说你们公司 es 的集群架构,索引数据大小,分片有多少,以及一些调优手段 。
2、elasticsearch 的倒排索引是什么
3、elasticsearch 索引数据多了怎么办,如何调优,部署
4、elasticsearch 是如何实现 master 选举的
5、详细描述一下 Elasticsearch 索引文档的过程
6、详细描述一下 Elasticsearch 搜索的过程?
7、Elasticsearch 在部署时,对 Linux 的设置有哪些优化方法
8、lucence 内部结构是什么?
9、Elasticsearch 是如何实现 Master 选举的?
10、Elasticsearch 中的节点(比如共 20 个),其中的 10 个选了一个master,另外 10 个选了另一个 master,怎么办?
Memcached 面试题(截取部分)
1、Memcached 是什么,有什么作用?
2、Memcached 服务分布式集群如何实现?
3、Memcached 服务特点及工作原理是什么?
4、简述 Memcached 内存管理机制原理?
5、memcached 是怎么工作的?
6、memcached 最大的优势是什么?
7、memcached 和 MySQL 的 query
8、memcached 和服务器的 local cache(比如 PHP 的 APC、mmap文件等)相比,有什么优缺点?
9、memcached 的 cache 机制是怎样的?
10、memcached 如何实现冗余机制?
Redis 面试题(截取部分)
1、什么是 Redis?
2、Redis 的数据类型?
3、使用 Redis 有哪些好处?
4、Redis 相比 Memcached 有哪些优势?
5、Memcache 与 Redis 的区别都有哪些?
6、Redis 是单进程单线程的?
7、一个字符串类型的值能存储最大容量是多少?
8、Redis 的持久化机制是什么?各自的优缺点?
9、Redis 常见性能问题和解决方案:
10、redis 过期键的删除策略?
MySQL 面试题(截取部分)
1、MySQL 中有哪几种锁?
2、MySQL 中有哪些不同的表格?
3、简述在 MySQL 数据库中 MyISAM 和 InnoDB 的区别
4、MySQL 中 InnoDB 支持的四种事务隔离级别名称,以及逐级之间的区别?
5、CHAR 和 VARCHAR 的区别?
6、主键和候选键有什么区别?
7、myisamchk 是用来做什么的?
8、如果一个表有一列定义为 TIMESTAMP,将发生什么?
9、你怎么看到为表格定义的所有索引?
10、LIKE 声明中的%和_是什么意思?
Java 并发编程(截取部分)
1、在 java 中守护线程和本地线程区别?
2、线程与进程的区别?
3、什么是多线程中的上下文切换?
4、死锁与活锁的区别,死锁与饥饿的区别?
5、Java 中用到的线程调度算法是什么?
6、什么是线程组,为什么在 Java 中不推荐使用?
7、为什么使用 Executor 框架?
8、在 Java 中 Executor 和 Executors 的区别?
9、如何在 Windows 和 Linux 上查找哪个线程使用的 CPU 时间最长?
10、什么是原子操作?在 Java Concurrency API 中有哪些原子类(atomic classes)?
部分答案参考
看完上面的内容,相信大家已经有了清晰的目标与方向,接下来就是查找学习资料了,我们为大家准备了一套体系化的架构师学习资料包,供大家参考,学习资料包内容及领取方法如下:
资料免费领取方式——Q裙:668470172 或者VX:13272413561
资料免费领取方式:
资料免费领取方式——Q裙:668470172 或者VX:13272413561
趁年轻,使劲拼!!