阅读 174

程序员去大公司面试,Java岗大厂面试官常问的那些问题,进阶学习

程序员去大公司面试,Java岗大厂面试官常问的那些问题,进阶学习

前言

这段时间一直在学习Netty相关知识,因为涉及知识点比较多,也走了不少弯路。目前网上关于Netty学习资料琳琅满目,不知如何下手,其实大家都是一样的,学习方法和技巧都是总结出来的,我们在没有找到很好的方法之前不如按部就班先从基础开始,一般从总分总的渐进方式,既观森林,又见草木。


Netty是一款提供异步的、事件驱动的网络应用程序框架和工具,是基于NIO客户端、服务器端的编程框架。所以这里我们先以NIO和依赖相关的基础铺垫来进行剖析讲解,从而作为Netty学习之旅的一个开端。


面试题模块介绍:



一、Java 基础

JDK 和 JRE 有什么区别?

== 和 equals 的区别是什么?

两个对象的 hashCode()相同,则 equals()也一定为 true,对吗?

final 在 java 中有什么作用?

java 中的 Math.round(-1.5) 等于多少?

String 属于基础的数据类型吗?

java 中操作字符串都有哪些类?它们之间有什么区别?

String str="i"与 String str=new String(“i”)一样吗?

如何将字符串反转?

String 类的常用方法都有那些?

抽象类必须要有抽象方法吗?

普通类和抽象类有哪些区别?

抽象类能使用 final 修饰吗?

接口和抽象类有什么区别?

java 中 IO 流分为几种?

BIO、NIO、AIO 有什么区别?

Files的常用方法都有哪些?

二、容器

java 容器都有哪些?

Collection 和 Collections 有什么区别?

List、Set、Map 之间的区别是什么?

HashMap 和 Hashtable 有什么区别?

如何决定使用 HashMap 还是 TreeMap?

说一下 HashMap 的实现原理?

说一下 HashSet 的实现原理?

ArrayList 和 LinkedList 的区别是什么?

如何实现数组和 List 之间的转换?

ArrayList 和 Vector 的区别是什么?

Array 和 ArrayList 有何区别?

在 Queue 中 poll()和 remove()有什么区别?

哪些集合类是线程安全的?

迭代器 Iterator 是什么?

Iterator 怎么使用?有什么特点?

Iterator 和 ListIterator 有什么区别?

怎么确保一个集合不能被修改?

三、多线程

并行和并发有什么区别?

线程和进程的区别?

守护线程是什么?

创建线程有哪几种方式?

说一下 runnable 和 callable 有什么区别?

线程有哪些状态?

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

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

线程的 run()和 start()有什么区别?

创建线程池有哪几种方式?

线程池都有哪些状态?

线程池中 submit()和 execute()方法有什么区别?

在 java 程序中怎么保证多线程的运行安全?

多线程锁的升级原理是什么?

什么是死锁?

怎么防止死锁?

ThreadLocal 是什么?有哪些使用场景?

说一下 synchronized 底层实现原理?

synchronized 和 volatile 的区别是什么?

synchronized 和 Lock 有什么区别?

synchronized 和 ReentrantLock 区别是什么?

说一下 atomic 的原理?

四、反射

什么是反射?

什么是 java 序列化?什么情况下需要序列化?

动态代理是什么?有哪些应用?

怎么实现动态代理?

五、对象拷贝

为什么要使用克隆?

如何实现对象克隆?

深拷贝和浅拷贝区别是什么?

六、Java Web

jsp 和 servlet 有什么区别?

jsp 有哪些内置对象?作用分别是什么?

说一下 jsp 的 4 种作用域?

session 和 cookie 有什么区别?

说一下 session 的工作原理?

如果客户端禁止 cookie 能实现 session 还能用吗?

spring mvc 和 struts 的区别是什么?

如何避免 sql 注入?

什么是 XSS 攻击,如何避免?

什么是 CSRF 攻击,如何避免?

七、异常

hrow 和 throws 的区别?

final、finally、finalize 有什么区别?

try-catch-finally 中哪个部分可以省略?

try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?

常见的异常类有哪些?

八、网络

http 响应码 301 和 302 代表的是什么?有什么区别?

forward 和 redirect 的区别?

简述 tcp 和 udp的区别?

tcp 为什么要三次握手,两次不行吗?为什么?

说一下 tcp 粘包是怎么产生的?

OSI 的七层模型都有哪些?

get 和 post 请求有哪些区别?

如何实现跨域?

说一下 JSONP 实现原理?

九、设计模式

说一下你熟悉的设计模式?

简单工厂和抽象工厂有什么区别?

十、Spring/Spring MVC

什么是spring?

Spring的俩大核心概念

Spring框架的设计目标,设计理念,和核心是什么

Spring由哪些模块组成?

Spring 框架中都用到了哪些设计模式?

使用 Spring 有哪些方式?

spring 支持几种 bean 的作用域?

spring 自动装配 bean 有哪些方式?

spring 事务实现方式有哪些?

什么是Spring MVC?简单介绍下你对Spring MVC的理解?

Spring MVC的主要组件?

什么是Spring MVC框架的控制器?

MVC是什么?MVC设计模式的好处有哪些

Spring MVC常用的注解有哪些?

Spring MVC与Struts2区别

Spring MVC怎么样设定重定向和转发的?

Spring MVC的异常处理?

什么是Spring MVC框架的控制器?

说一下 spring mvc 运行流程?

spring mvc 有哪些组件?

@RequestMapping 的作用是什么

@Autowired 的作用是什么?

十一、Spring Boot/Spring Cloud

什么是 spring boot?

为什么要用 spring boot?

spring boot 核心配置文件是什么?

spring boot 配置文件有哪几种类型?它们有什么区别?

spring boot 有哪些方式可以实现热部署?

jpa 和 hibernate 有什么区别?

什么是 spring cloud?

spring cloud 断路器的作用是什么?

spring cloud 的核心组件有哪些?

十二、Hibernate

为什么要使用 hibernate?

什么是 ORM 框架?

hibernate 中如何在控制台查看打印的 sql 语句?

hibernate 有几种查询方式?

hibernate 实体类可以被定义为 final 吗?

在 hibernate 中使用 Integer 和 int 做映射有什么区别?

hibernate 是如何工作的?

get()和 load()的区别?

说一下 hibernate 的缓存机制?

hibernate 对象有哪些状态?

在 hibernate 中 getCurrentSession 和 openSession 的区别是什么?

hibernate 实体类必须要有无参构造函数吗?为什么?

十三、Mybatis

MyBatis是什么?

Mybatis优缺点

Hibernate 和 MyBatis 的区别

为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?

传统JDBC开发存在什么问题?

JDBC编程有哪些不足之处,MyBatis是如何解决的?

MyBatis和Hibernate的适用场景?

MyBatis编程步骤是什么样的?

请说说MyBatis的工作原理

MyBatis的功能架构是怎样的

MyBatis的框架架构设计是怎么样的

什么是DBMS

Mybatis都有哪些Executor执行器?它们之间的区别是什么?

Mybatis中如何指定使用哪一种Executor执行器?

Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?

Mybatis如何执行批量操作

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

Mapper 编写有哪几种方式?

什么是MyBatis的接口绑定?有哪些实现方式?

使用MyBatis的mapper接口调用时有哪些要求?

Mybatis是如何将sql执行结果封装为目标对象并返回的?都有哪些映射形式?

简述Mybatis的Xml映射文件和Mybatis内部数据结构之间的映射关系?

Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签?

Mybatis是否可以映射Enum枚举类?

简述Mybatis的插件运行原理,以及如何编写一个插件。

Mybatis的一级、二级缓存

十四、RabbitMQ

什么是MQ

MQ的优点

解耦、异步、削峰是什么?。

消息队列有什么缺点

你们公司生产环境用的是什么消息中间件?

Kafka、ActiveMQ、RabbitMQ、RocketMQ 有什么优缺点?

MQ 有哪些常见问题?如何解决这些问题?

什么是RabbitMQ?

rabbitmq 的使用场景

RabbitMQ的工作模式

如何保证RabbitMQ消息的顺序性?

消息如何分发?

消息基于什么传输?

如何保证消息不被重复消费?或者说,如何保证消息消费时的幂等性?

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

如何保证RabbitMQ消息的可靠传输?

为什么不应该对所有的 message 都使用持久化机制?

如何保证高可用的?RabbitMQ 的集群

如何解决消息队列的延时以及过期失效问题?消息队列满了以后该怎么处理?有几百万消息持续积压几小时,怎么办?

设计MQ思路?

十五、Kafka

kafka 可以脱离 zookeeper 单独使用吗?为什么?

kafka 有几种数据保留的策略?

kafka 同时设置了 7 天和 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?

什么情况会导致 kafka 运行变慢?

使用 kafka 集群需要注意什么?

十六、Zookeeper

zookeeper 是什么?

ZooKeeper 提供了什么?

Zookeeper 怎么保证主从节点的状态同步?

zookeeper 是如何保证事务的顺序一致性的?

Zookeeper Watcher 机制 – 数据变更通知

集群中为什么要有主节点?

集群中有 3 台服务器,其中一个节点宕机,这个时候 zookeeper 还可以使用吗?

说一下 zookeeper 的通知机制?

Watcher 特性总结

客户端注册 Watcher 实现

服务端处理 Watcher 实现

Zookeeper 下 Server 工作状态

zookeeper 是如何保证事务的顺序一致性的?

分布式集群中为什么会有 Master主节点?

zookeeper 负载均衡和 nginx 负载均衡区别

Zookeeper 有哪几种几种部署模式?

集群支持动态添加机器吗?

Zookeeper 对节点的 watch 监听通知是永久的吗?为什么不是永久的?

Zookeeper 的 java 客户端都有哪些?

chubby 是什么,和 zookeeper 比你怎么看?

Zookeeper 都有哪些功能?

说一下 Zookeeper 的通知机制?

Zookeeper 和 Dubbo 的关系?

十七、MySql

为什么要使用数据库?

什么是MySQL?

MySql, Oracle,Sql Service的区别

mysql有关权限的表都有哪几个

MySQL的binlog有有几种录入格式?分别有什么区别?

数据库经常使用的函数?

mysql有哪些数据类型?

MySQL存储引擎MyISAM与InnoDB区别

MyISAM索引与InnoDB索引的区别?

什么是索引?索引有哪些优缺点?

怎么创建索引的,有什么好处,有哪些分类

索引有哪几种类型?

索引的数据结构(b树,hash)

索引算法有哪些?

创建索引的三种方式

百万级别或以上的数据如何删除

B树和B+树的区别

事物的四大特性(ACID)介绍一下?

什么是事务的隔离级别?MySQL的默认隔离级别是什么?

从锁的类别上分MySQL都有哪些锁呢?

MySQL中InnoDB引擎的行锁是怎么实现的?

什么是存储过程?有哪些优缺点?

什么是触发器?触发器的使用场景有哪些?

SQL语句主要分为哪几类

怎么优化SQL查询语句吗

如何定位及优化SQL语句的性能问题?创建的索引有没有被使用到?或者说怎么才可以知道这条语句运行很慢的原因?

SQL的生命周期?

MySQL数据库cpu飙升到500%的话他怎么处理?

备份计划,mysqldump以及xtranbackup的实现原理

十八、Redis

什么是Redis?

Redis有哪些优缺点?

使用redis有哪些好处?

为什么要用 Redis / 为什么要用缓存

为什么要用 Redis 而不用 map/guava 做缓存?

Redis为什么这么快

Redis有哪些数据类型

Redis的应用场景

Redis 的持久化机制是什么?各自的优缺点?

如何选择合适的持久化方式

Redis持久化数据和缓存怎么做扩容?

Redis的过期键的删除策略

Redis key的过期时间和永久有效分别怎么设置?

我们知道通过expire来设置key 的过期时间,那么对过期的数据怎么处理呢?

MySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据

Redis主要消耗什么物理资源?

Redis的内存用完了会发生什么?

Redis如何做内存优化?

Redis事务的概念

Redis事务支持隔离性吗

redis 集群模式的工作原理能说一下么?

在集群模式下,redis 的 key 是如何寻址的?

分布式寻址都有哪些算法?

了解一致性 hash 算法吗?

Redis集群的主从复制模型是怎样的?

生产环境中的 redis 是怎么部署的?

Redis集群会有写操作丢失吗?为什么?

Redis是单线程的,如何提高多核CPU的利用率?

你知道有哪些Redis分区实现方案?

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

分布式Redis是前期做还是后期规模上来了再做好?为什么?

Redis和Redisson有什么关系?

十九、JVM

我们开发人员编写的Java代码是怎么让电脑认识的


Jdk和Jre和JVM的区别


说一下 JVM由那些部分组成,运行流程是什么?


说一下 JVM 运行时数据区


详细的介绍下程序计数器?(重点理解)


详细介绍下Java虚拟机栈?(重点理解


你能给我详细的介绍Java堆吗?(重点理解)


能不能解释一下本地方法栈?


能不能解释一下方法区(重点理解)


什么是JVM字节码执行引擎


你听过直接内存吗?


知道垃圾收集系统吗?


堆栈的区别是什么?


深拷贝和浅拷贝


Java会存在内存泄漏吗?请说明为什么?


JVM 中都有哪些引用类型?


怎么判断对象是否可以被回收?


对象什么时候可以被垃圾器回收


JVM 垃圾回收算法有哪些?


JVM中的永久代中会发生垃圾回收吗


说一下 JVM 有哪些垃圾回收器?


说一下 JVM 调优的工具?


俗话说,好学者临池学书,不过网络时代,对于大多数的我们来说,我倒是觉得学习意识的觉醒很重要,这是开始学习的转折点,比如看到对自己方向发展有用的信息,先收藏一波是一波,比如如果你觉得我这篇文章ok,先点赞收藏一波。这样,等真的沉下心来学习,不至于被找资料分散了心神。慢慢来,先从点赞收藏做起,加油吧!


总结

阿里伤透我心,疯狂复习刷题,终于喜提offer 哈哈~好啦,不闲扯了,文章开头说要免费给大家分享我的复习资料,下面就给大家展示一下——点击这里免费获取我的复习刷题宝典




1、JAVA面试核心知识整理(PDF):包含JVM,JAVA集合,JAVA多线程并发,JAVA基础,Spring原理,微服务,Netty与RPC,网络,日志,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算共30个章节。




2、Redis学习笔记及学习思维脑图




3、数据面试必备20题+数据库性能优化的21个最佳实践




,Spring原理,微服务,Netty与RPC,网络,日志,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算共30个章节。


[外链图片转存中…(img-wsZnbWHq-1620139399132)]


2、Redis学习笔记及学习思维脑图


[外链图片转存中…(img-AMEdkYNk-1620139399133)]


3、数据面试必备20题+数据库性能优化的21个最佳实践


[外链图片转存中…(img-KD0uDDLL-1620139399135)]

————————————————

版权声明:本文为CSDN博主「Java范德萨」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/m0_56830725/article/details/116406601


文章分类
后端
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐