写点什么

2020 年“有史以来”全网最全 1309 道 BAT 大厂 java 面试题(附答案分享)

  • 2021 年 11 月 10 日
  • 本文字数:3333 字

    阅读完需:约 11 分钟

  • 异常的处理机制有几种?

  • 如何自定义一个异常

  • try catch fifinally,try 里有 return,finally 还执行么?

  • Excption 与 Error 包结构

  • Thow 与 thorws 区别

  • Error 与 Exception 区别?

  • error 和 exception 有什么区别



Java 中的 IO 与 NIO


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


  • Java 中 IO 流?

  • Java IO 与 NIO 的区别

  • 常用 io 类有哪些

  • 字节流与字符流的区别

  • 阻塞 IO 模型

  • 非阻塞 IO 模型

  • 多路复用 IO 模型

  • 信号驱动 IO 模型

  • 异步 IO 模型

  • JAVA NIO



Java 反射


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


  • 除了使用 new 创建对象之外,还可以用什么方法创建对象?

  • Java 反射创建对象效率高还是通过 new 创建对象的效率高?

  • java 反射的作用

  • 哪里会用到反射机制?

  • 反射的实现方式:

  • 实现 Java 反射的类:

  • 反射机制的优缺点:

  • Java 反射 API

  • 反射使用步骤(获取 Class 对象、调用对象方法)

  • 获取 Class 对象有几种方法

  • 利用反射动态创建对象实例



Java 序列化


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


  • 什么是 java 序列化,如何实现 java 序列化?

  • 保存(持久化)对象及其状态到内存或者磁盘

  • 序列化对象以字节数组保持-静态成员不保存

  • 序列化用户远程对象传输

  • Serializable 实现序列化

  • writeObject 和 readObject 自定义序列化策略

  • 序列化 ID

  • 序列化并不保存静态变量

  • Transient 关键字阻止该变量被序列化到文件中

  • 序列化(深 clone 一中实现)



多线程 &并发


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


JAVA 并发知识库


  • Java 中实现多线程有几种方法

  • 继承 Thread 类

  • 实现 Runnable 接口。

  • ExecutorService、 Callable、 Future 有返回值线程

  • 基于线程池的方式

  • 4 种线程池

  • 如何停止一个正在运行的线程

  • notify()和 notifyAll()有什么区别?

  • sleep()和 wait() 有什么区别?

  • volatile 是什么?可以保证有序性吗?



JVM


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


  • java 中会存在内存泄漏吗,请简单描述。

  • 64 位 JVM 中,int 的长度是多数?

  • Serial 与 Parallel GC 之间的不同之处?

  • 32 位和 64 位的 JVM,int 类型变量的长度是多数?

  • Java 中 WeakReference 与 SoftReference 的区别?

  • JVM 选项 -XX:+UseCompressedOops 有什么作用?为什么要使用

  • 怎样通过 Java 程序来判断 JVM 是 32 位 还是 64 位?

  • 32 位 JVM 和 64 位 JVM 的最大堆内存分别是多数?

  • JRE、JDK、JVM 及 JIT 之间有什么不同?

  • 解释 Java 堆空间及 GC?



Mysql


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


  • 数据库存储引擎

  • InnoDB(B+树)

  • TokuDB( Fractal Tree-节点带数据)

  • Memory

  • 数据库引擎有哪些

  • InnoDB 与 MyISAM 的区别

  • 索引

  • 常见索引原则有

  • 数据库的三范式是什么

  • 第一范式(1st NF - 列都是不可再分)



Redis


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


  • 什么是 Redis?

  • Redis 与其他 key-value 存储有什么不同?

  • Redis 的数据类型?

  • 使用 Redis 有哪些好处?

  • Redis 相比 Memcached 有哪些优势?

  • Memcache 与 Redis 的区别都有哪些?

  • Redis 是单进程单线程的?

  • 一个字符串类型的智能存储最大容量是多少?

  • Redis 持久化机制

  • 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题



Memcached


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


  • Memcached 是什么,有什么作用?

  • memcached 服务在企业集群架构中有哪些应用场景?

  • Memcached 服务分布式集群如何实现?

  • Memcached 服务特点及工作原理是什么?

  • 简述 Memcached 内存管理机制原理?

  • memcached 是怎么工作的?

  • memcached 最大的优势是什么?

  • memcached 和 MySQL 的 query

  • memcached 和服务器的 local cache(比如 PHP 的 APC、mmap 文件等)相比,有什么优缺点?

  • memcached 的 cache 机制是怎样的?

  • memcached 如何实现冗余机制?



MongoDB


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


  • mongodb 是什么?

  • mongodb 有哪些特点?

  • 你说的 NoSQL 数据库是什么意思?NoSQL 与 RDBMS 直接有什么区别?为什么要使用和不使用 NoSQL 数据库?说一说 NoSQL 数据库的几个优点?

  • NoSQL 数据库有哪些类型?

  • MySQL 与 MongoDB 之间最基本的差别是什么?

  • 你怎么比较 MongoDB、CouchDB 及 CouchBase?

  • MongoDB 成为最好 NoSQL 数据库的原因是什么?

  • journal 回放在条目(entry)不完整时(比如恰巧有一个中途故障了)会遇到问题吗?

  • 分析器在 MongoDB 中的作用是什么?

  • 名字空间(namespace)是什么?



Spring


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


  • 不同版本的 Spring Framework 有哪些主要功能?

  • 什么是 Spring Framework?

  • 列举 Spring Framework 的优点。

  • Spring Framework 有哪些不同的功能?

  • Spring Framework 中有多少个模块,它们分别是什么?

  • 什么是 Spring 配置文件?

  • Spring 应用程序有哪些不同组件?

  • 使用 Spring 有哪些方式?

  • 什么是 Spring IOC 容器?

  • 什么是依赖注入?



Spring Boot


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


  • 什么是 Spring Boot?

  • 为什么要用 SpringBoot

  • Spring Boot 有哪些优点?

  • Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?

  • 运行 Spring Boot 有哪几种方式

  • 如何理解 Spring Boot 中的 Starters?

  • 如何在 Spring Boot 启动的时候运行一些特定的代码?

  • Spring Boot 需要独立的容器运行吗?

  • Spring Boot 中的监视器是什么?

  • 如何使用 Spring Boot 实现异常处理?



Spring Cloud


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


  • 什么是 Spring Cloud?

  • 使用 Spring Cloud 有什么优势?

  • 服务注册和发现是什么意思?Spring Cloud 如何实现?

  • 负载平衡的意义什么?

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

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

  • 什么是 Netflix Feign?它的优点是什么?

  • 什么是 Spring Cloud Bus?我们需要它吗?

  • 什么是微服务

  • 什么是服务熔断?什么是服务降级



RabbitMQ


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


  • 什么是 rabbitmq

  • 为什么要使用 rabbitmq

  • 使用 rabbitmq 的场景

  • 如何确保消息正确地发送至 RabbitMQ? 如何确保消息接收方消费了消息?

  • 如何避免消息重复投递或重复消费?

  • 消息基于什么传输?

  • 消息如何分发?

  • 消息怎么路由?

  • 如何确保消息不丢失?

  • 使用 RabbitMQ 有什么好处?



Dubbo


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


  • 为什么要用 Dubbo?

  • Dubbo 的整体架构设计有哪些分层?

  • 默认使用的是什么通信框架,还有别的选择吗?

  • 服务调用是阻塞的吗?

  • 一般使用什么注册中心?还有别的选择吗?

  • 默认使用什么序列化框架,你知道的还有哪些?

  • 服务提供者能实现失效提出是什么原理?

  • 服务上线怎么不影响旧版本?

  • 如何解决服务调用链过长的问题?

  • 说说核心的配置有哪些?



MyBatis


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


  • 什么是 Mybatis?

  • Mybaits 的优点

  • MyBatis 框架的缺点

  • MyBatis 框架适用场合

  • MyBatis 与 Hibernate 有哪些不同?

  • {}和 ${}的区别是什么?


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


  • 当实体类中的属性名和表中的字段名不一样 ,怎么办 ?

  • 模糊查询 like 语句该怎么写?

  • 通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时,方法能重载吗?

  • 如何获取自动生成的(主)键值?



ZooKeeper


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


  • 什么是 Zookeeper?

  • Zookeeper 如何保证了分布式一致性特性?

  • ZooKeeper 提供了什么?

  • Zookeeper 文件系统

  • ZAB 协议?

  • 四种类型的数据节点 Znode

  • Zookeeper Watcher 机制 – 数据变更通知

  • 客户端注册 Watcher 实现

  • 服务端处理 Watcher 实现

  • 客户端回调 Watcher


[图片上传失败…(image-7334ca-1600669130311)]


数据结构


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


  • 栈(stack)

  • 队列(queue)

  • 链表(Link)

  • 散列表(Hash Table)

  • 排序二叉树

  • 前缀树

  • 红黑树

  • B-TREE

  • 位图



Elasticsearch


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

评论

发布
暂无评论
2020年“有史以来”全网最全1309道BAT大厂java面试题(附答案分享)