美文网首页面试
Java 常见面试题整理

Java 常见面试题整理

作者: 技术灭霸 | 来源:发表于2019-05-08 23:26 被阅读221次

    操作系统

    • 说一下线程和进程,它们的区别
    • 同步和异步的区别
    • 阻塞和非阻塞的区别
    • 操作系统中死锁的四个必要条件
    • mmap和普通文件读写的区别,mmap的注意点
    • CPU密集型和IO密集型的区别

    Linux

    • linux 用过的命令
    • kill 用法,某个进程杀不掉的原因(进入内核态,忽略 kill 信号)
    • 系统管理命令(如查看内存- 网络情况)
    • 管道的使用
    • grep 的使用,一定要掌握,每次都会问在文件中查找
    • shell 脚本
    • find 命令
    • awk 使用
    • 讲一下linux的Swap分区
    • 硬链接和软连接区别
    • 讲一下epoll的基本原理,优点
    • 讲一下内核态与用户态,为什么要有用户态和内核态,如何切换
    • 讲一下五种IO模型

    计算机网络

    • 网络为什么要分层
    • 为什么有IP地址还需要MAC地址
    • IP 地址子网划分
    • DNS 解析过程
    • URI和URL区别
    • 说一下 TCP 和 UDP 的区别,优缺点
    • TCP如何保证可靠传输?怎么做到不丢,不重,不漏(三次握手、滑动窗口、流量控制、拥塞控制)
    • TCP三次握手、TCP四次挥手
    • TCP粘包和拆包产生的原因?解决策略?
    • 谈一下你对 HTTP 的理解?
    • http2 比1.1主要改进了什么,有什么好的办法解决头部阻塞嘛?
    • 既然说 HTTP 是无状态的,那服务器怎么记住上次请求的用户?
    • GET和POST区别
    • 讲一下你熟悉的HTTP状态码,它们的含义是什么?
    • 讲一下一次完整的HTTP请求过程
    • HTTPS和HTTP的区别,https是如何保证数据传输的安全?
    • Session 和 Cookie 区别?

    设计模式

    • 说一下你熟悉的设计模式?
    • 简单工厂和抽象工厂有什么区别?
    • 什么是单例模式?在什么情况下需要使用单例模式?

    Java基础系列

    容器

    • Collection 和 Collections 有什么区别?
    • List、Set、Map 之间的区别是什么?
    • ArrayList初始化默认长度、扩容、拷贝、增加和删除时间复杂度和空间复杂度
    • ArrayList 是一个线程安全的集合类吗?
    • ArrayList 和 LinkedList 的区别是什么?
    • 如何实现数组和 List 之间的转换?
    • ArrayList 和 Vector 的区别是什么?
    • 迭代器 Iterator 是什么?怎么使用?有什么特点?
    • 在 Queue 中 poll()和 remove()有什么区别?
    • 说一下 HashMap 的底层数据结构?
    • HashMap 和 Hashtable 有什么区别?
    • 如何决定使用 HashMap 还是 TreeMap?
    • HashMap 存储元素时 key 完全一样该怎么处理?
    • HashMap 的默认长度是多少?如何扩容的?
    • Hash 会有什么问题 ?怎么避免或者减少哈希碰撞 ?
    • JDK 1.8 的 HashMap 有什么变化?为什么 JDK 1.7 是头插法,JDK 1.8 是尾插法?
    • ConcurrentHashMap 和 HashMap 的区别?为什么 ConcurrentHashMap 会线程安全?
    • ConcurrentHashMap 虽然是线程安全的,但它也存在什么问题?
    • 了解 TreeMap 吗?TreeMap 最大的特点是什么?为什么已经有了 HashMap 了还要有 TreeMap 类?
    • 说一下 Fail-Fast 机制,结合源码说一下
    • 哪些集合类是线程安全的?
    • 怎么确保一个集合不能被修改?
    • 判断一个集合类是否为线程安全的机制是什么?

    多线程

    • 线程有哪些状态?
    • 并行和并发有什么区别?
    • 线程和进程的区别?
    • 守护线程是什么?
    • 创建线程有哪几种方式?
    • 说一下 runnable 和 callable 有什么区别?
    • sleep() 和 wait() 有什么区别?
    • notify()和 notifyAll()有什么区别?
    • 为什么线程通信的方法wait(), notify()和notifyAll()被定义在Object类里?
    • 线程的 run()和 start()有什么区别?
    • 什么是线程安全?在 java 程序中怎么保证多线程的运行安全?
    • 锁的升级原理是什么?
    • 对象锁和静态锁之间的区别
    • 什么是死锁?怎么防止死锁?
    • ThreadLocal 是什么?有哪些使用场景?
    • 说一下 synchronized 底层实现原理?
    • synchronized 和 volatile 的区别是什么?
    • synchronized 和 Lock 有什么区别?
    • synchronized 和 ReentrantLock 区别是什么?
    • 说一下 atomic 的原理?
    • CAS是什么?缺点
    • 说一下 AQS的原理?
    • 如何停止一个线程?
    • final域的内存语义

    线程池

    • 线程池的实现原理,为什么要用线程池
    • 线程池中Executor、ExecuteService、Executors 的区别
    • 线程池都有哪些状态?
    • 线程池中 submit()和 execute()方法有什么区别?
    • 线程池都有哪几种工作队列?
    • 怎么理解无界队列和有界队列?
    • ThreadPoolExecutor执行的策略
    • 说说几种常见的线程池及使用场景?特点?为什么不推荐通过Executors直接创建线程池
    • 四种拒绝策略
    • 线程池ThreadPoolExecutor参数如何设置
    • 单机上一个线程池正在处理服务,如果忽然断电了怎么办(正在处理和阻塞队列里的请求怎么处理)?

    反射

    • 什么是反射?
    • 什么是 Java 序列化?什么情况下需要序列化?
    • 动态代理是什么?有哪些应用?
    • 怎么实现动态代理?

    对象拷贝

    • 为什么要使用克隆?
    • 如何实现对象克隆?
    • 深拷贝和浅拷贝区别是什么?

    异常

    • Java 异常的体系结构
    • throw 和 throws 的区别?
    • final、finally、finalize 有什么区别?
    • try-catch-finally 中哪个部分可以省略?
    • try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?
    • 常见的异常类有哪些?

    JVM

    • 说一下对jvm的理解,jvm的组成部分,各个部分的存储内容以及常见的jvm的问题排查步骤。
    • 对JVM熟不熟悉?简单说说类加载过程,里面执行的那些操作?
    • JVM方法区存储内容 是否会动态扩展 是否会出现内存溢出 出现的原因有哪些。
    • 介绍介绍CMS。
    • 介绍介绍G1。
    • 为什么jdk8用metaspace数据结构用来替代perm?
    • 简单谈谈堆外内存以及你的理解和认识。
    • JVM的内存模型的理解,threadlocal使用场景及注意事项?
    • JVM老年代和新生代的比例?
    • jstack,jmap,jutil分别的意义?如何线上排查JVM的相关问题?
    • Java虚拟机中,数据类型可以分为哪几类?
    • 怎么理解栈、堆?堆中存什么?栈中存什么?
    • 为什么要把堆和栈区分出来呢?栈中不是也可以存储数据吗?
    • 在Java中,什么是是栈的起始点,同是也是程序的起始点?
    • 为什么不把基本类型放堆中呢?
    • Java中的参数传递时传值呢?还是传引用?
    • Java中有没有指针的概念?
    • Java中,栈的大小通过什么参数来设置?
    • 一个空Object对象的占多大空间?
    • 对象引用类型分为哪几类?
    • 讲一讲垃圾回收算法。
    • 如何解决内存碎片的问题?
    • 如何解决同时存在的对象创建和对象回收问题?
    • 讲一讲内存分代及生命周期。
    • 什么情况下触发垃圾回收?
    • 如何选择合适的垃圾收集算法?
    • JVM中最大堆大小有没有限制?
    • 堆大小通过什么参数设置?
    • JVM有哪三种垃圾回收器?
    • 吞吐量优先选择什么垃圾回收器?响应时间优先呢?
    • 如何进行JVM调优?有哪些方法?
    • 如何理解内存泄漏问题?有哪些情况会导致内存泄露?如何解决?

    MySQL

    • 说一下 ACID 是什么?
    • 说一下四种隔离级别,默认的隔离级别是什么,怎么避免不可重复读?
    • char 和 varchar 的区别是什么?
    • float 和 double 的区别是什么?
    • mysql 的内连接、左连接、右连接有什么区别?
    • mysql 索引是怎么实现的?
    • B+树索引和哈希索引的区别
    • B树和B+树的区别
    • 聚集索引和辅助索引
    • 什么情况下应不建或少建索引,导致索引失效的一些情况
    • key和index的区别
    • 怎么验证 mysql 的索引是否满足需求?
    • 说一下 mysql 常用的引擎?MyISAM和InnoDB的区别?如何选择?
    • 说一下 mysql 的行锁和表锁?
    • 锁的算法(Record Lock、Gap Lock、Next-Key Lock)
    • MySQL怎么实现redo log和binlog的一致性
    • 说一下乐观锁和悲观锁?
    • 说一下MySQL分区怎么实现,对业务层透明吗?MySQL支持的分区类型有哪些?使用场景?分区与分表的区别?
    • mysql主从同步原理
    • 说一下MVVC
    • mysql 问题排查都有哪些手段?
    • 如何做 mysql 的性能优化?

    Netty

    • Netty为什么比NIO快?
    • 讲一下Netty零拷贝原理,为什么会有内核空间?怎么管理?
    • NIO一定比IO快吗?什么情况下会比IO慢?

    Spring

    • 为什么要使用 spring?
    • 讲一下aop的实现原理?JDK动态代理和CGLIB代理的区别
    • 讲一下ioc的实现原理?
    • spring 有哪些主要模块?
    • spring 常用的注入方式有哪些?
    • spring 中的 bean 是线程安全的吗?
    • spring 支持几种 bean 的作用域?
    • spring 自动装配 bean 有哪些方式?
    • spring 事务实现方式有哪些?事务失效的几种原因
    • 说一下 spring 的事务隔离?
    • 说一下 spring mvc 运行流程?
    • spring mvc 有哪些组件?
    • @RequestMapping 的作用是什么?
    • @Autowired 的作用是什么?

    Spring Boot

    • 什么是 Spring Boot?为什么要用 Spring Boot?和Spring有什么区别?
    • Spring Boot 核心配置文件是什么?
    • Spring Boot配置文件有哪几种类型?它们有什么区别?
    • Spring Boot 有哪些方式可以实现热部署?
    • 微服务怎么拆分
    • 讲一下DDD

    MyBatis

    • mybatis的特性
    • mybatis的#号和$号有什么区别
    • mybatis如何进行类型转换
    • mybatis的xml有什么标签
    • mybatis底层如何加载mapper,以及SQL语句具体怎么执行
    • mybatis 有哪些执行器(Executor)?
    • mybatis 有几种分页方式?
    • RowBounds 是一次性查询全部结果吗?为什么?
    • mybatis 逻辑分页和物理分页的区别是什么?
    • mybatis 是否支持延迟加载?延迟加载的原理是什么?
    • MyBatis 如何处理批量请求?
    • 说一下 mybatis 的一级缓存和二级缓存?(高频)
    • mybatis 分页插件的实现原理是什么?
    • mybatis 如何编写一个自定义插件?

    消息队列

    • 说说你使用过什么消息中间件?
    • 为什么要在系统里引入消息中间件?
    • 消息中间件技术选型为什么是RabbitMQ?技术选型的依据是什么?
    • 怎么保证消息中间件的高可用性?避免消息中间件故障后引发系统整体故障?
    • RabbitMQ的高可用性怎么实现。
    • 怎么保证投递出去的消息只有一条,不会出现重复的数据?
    • 消息重复是什么造成的,从生产端和消费端两个角度来考虑
    • 如何保证消息的顺序性?如果不需要保证消息顺序,为什么不需要?
    • 是否遇到过消息积压的生产故障?如果没遇到过,你考虑一下如何应对?
    • 说说RabbitMQ的底层架构原理,逻辑架构、物理架构以及数据持久化机制?
    • 你们RabbitMQ的最高峰QPS每秒是多少?线上如何部署的,部署了多少台机器,机器的配置如何?
    • 说说Kafka的底层架构原理,磁盘上数据如何存储的,整体分布式架构是如何实现的?
    • 说说Kafka是如何保证数据的高容错性的?零拷贝等技术是如何运用的?高吞吐量下如何优化生产者和消费者的性能?
    • 说说你对Kafka源码的理解?
    • RocketMQ的一个特点是对分布式事务的支持,说说他在分布式事务支持的底层原理?
    • RocketMQ的源码看过么,聊聊你对RocketMQ源码的理解?
    • 如果让你来动手实现一个分布式消息中间件,整体架构你会如何设计实现?

    Redis

    • Redis 都有哪些数据类型?它们的内部数据结构是什么?分别在哪些场景下使用比较合适?
    • Redis有人说是单线程和有人说是多线程,你怎么看?Redis 为什么是单线程的?
    • Redis 和 Memcached 有什么区别?为什么单线程的 Redis 比多线程的 Memcached 效率要高得多?
    • Redis 的线程模型是什么?讲一下多路I/O复用模型?
    • Redis主从复制是怎么实现的
    • 什么是 Redis 的雪崩和穿透?Redis 崩溃之后会怎么样?系统该如何应对这种情况?如何处理 Redis 的穿透?
    • Redis 的持久化有哪几种方式?区别?持久化机制具体底层是如何实现的?
    • redis 支持的 java 客户端都有哪些?jedis 和 redisson 有哪些区别?
    • 如何保证缓存与数据库的双写一致性?
    • Redis 的并发竞争问题是什么?如何解决?了解 Redis 事务的 CAS 方案吗?
    • Redis 集群模式的工作原理?Redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗?如何动态增加和删除一个节点?
    • Redis 怎么实现分布式锁?有什么缺陷?
    • Redis 如何做内存优化?
    • Redis 设置过期时间的原理?
    • Redis 淘汰策略有哪些?
    • Redis 常见的性能问题有哪些?该如何解决?
    • Redis 和MySQL区别,MySQL也有存储文档格式的存储引擎Memory,它们什么区别?

    Zookeeper

    • raft协议相比paxos的优劣

    Nginx

    • 讲一下nginx负载均衡,优势,Apache和Nginx区别
    • cgi和fastcgi区别
    • Nginx架构、模块关系、accept_mutex的实现以及多进程的负载均衡
    • nginx部署的时候出现502了吗,500什么时候出现的
    • Nginx负载均衡导致用户两次调用服务不在一个IP上,怎么保持连接

    MongoDB

    • MongoDB和MySQL区别,MySQL也有存储文档格式的存储引擎Archive,它们什么区别?

    Solr

    • Solr全量索引的时候发现数据有丢失,怎么处理?
    • Solr地理位置搜索的原理是什么?
    • 倒排索引的优势?

    相关文章

      网友评论

        本文标题:Java 常见面试题整理

        本文链接:https://www.haomeiwen.com/subject/qvwboqtx.html