代码编织梦想

Java大厂面试题04

世间最好的东西,是欢喜;世间最贵的善举,是结缘;
世间最大的力量,是忍耐;世间最强的愿力,是甘愿;

1.Spring Bean 的生命周期

  • Spring Bean的生命周期简单易懂。当一个bean实例被初始化时,需要执行一系列初始化操作以达到可用的状态。同样的,当一个bean不在被调用需要进行相关的析构操作,并从bean容器中移除。
  • Spring bean factory 负责管理在 spring 容器中被创建的bean的生命周期。Bean的生命周期由两组回调(call back)方法组成。
  • 初始化之后调用的回调方法
  • Spring框架提供了一下四种方法来管理bean的生命周期:
  1. InitializingBean 和 DisposableBean回调接口
  2. 针对特殊行为的其他Aware 接口
  3. Bean配置文件中的Custom initial()方法和 destroy()方法
  4. @PostConstruct 和 @PreDestroy 注解方法

2.说说 Spring AOP

  • 面向切面编程,在我们的应用中,需要做一些事情,但是这些事情与核心业务无关,比如,要记录所有update*方法的执行时间,操作人等等信息,记录到日志。
  • 通过spring 的 AOP 技术,就可以在不修改update*的代码的情况下完成该需求。

3.Spring AOP 实现原理

  • Spring AOP 中的动态代理主要有两种方式,JDK动态代理和CGLIB动态代理。JDK动态代理通过反射来接收被代理的类,并且要求被代理的类必须实现一个接口。JDK动态代理的核心是InvocationHandler接口和Proxy类。
  • 如果目标类没有实现接口,那么Spring AOP 会使用CGLIB来动态代理目标类。CGLIB(Code Generation Library),是一个代码生成的类库,可以在运行时动态的生成某个类的子类,注意:CGLIB是通过继承的方式做的动态代理,因此如果某个类被标记为final,那么它是无法使用CGLIB做动态代理的。

4.Spring 事务实现方式

  1. 编码方式
    • 所谓编程式事务指的是通过编码方式实现事务,即类似于JDBC编程实现事务管理
  2. 声明式事务管理方式
    • 基于xml配置文件的方式
    • 在业务方法上进行@Transaction注解,将事务规则应用到业务逻辑中

5.什么是 TCP 粘包/拆包

  1. 发送端给每个数据包添加包首部,首部中应该至少包含数据包的长度,这样接收端在接收到数据后,通过读取包首部的长度字段,便知道每一个数据包的实际长度了。
  2. 发送端将每个数据包封装为固定长度(不够的可以通过补0填充),这样接收端每次从接收缓存区中读取固定长度的数据就自然而然的把每个数据包拆分开来。
  3. 可以在数据包之间设置边界,通过添加特殊符合,这样接收端通过这个边界就可以将不同的数据包拆分开来

6.说说 Netty 的零拷贝

  • “零拷贝”是指在计算机操作的过程中,CPU不需要为数据在内存之间的拷贝消耗资源。而它通常是指在计算机在网络上发送文件时,不需要将文件内容拷贝到用户空间(User Space)而直接在内核空间(Kernel Space)中传输到网络的形式。

7.说说业务中,Netty 的使用场景

  1. 构建高性能、低延时的各种Java中间件,例如MQ、分布式框架、ESB消息总线等,Netty 主要作为基础通信框架提供高性能、低延时的通信服务;

  2. 公有或者私有协议的基础通信框架,例如可以基于Netty构建异步、高性能的WebSocket协议栈;

  3. 各个领域应用,例如大数据、游戏等Netty作为高性能的通信框架用于各模块的数据分发、传输和汇总,实现模块之间高性能通信。

人生,唯有不断地舍,方可真正有所得

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_71566302/article/details/130915204