java八股系列——依赖注入的方式

文章讨论了依赖注入的三种方式——构造方法注入、setter注入和属性注入,以及Spring团队推荐的构造器注入。同时,对比了Spring的@Autowired和J2EE的@Resource注解,包括它们的装配策略和使用场景。文章建议在属性注入时使用@Resource,以减少与Spring的耦合。

依赖注入有三种方式:

  • 构造方法注入
    • 优点:固定依赖注入的顺序,解决循环依赖的问题。
    • 缺点:注入过多时会显得臃肿。
  • setter注入
    • 优点:只有对象是需要被注入的时候,才会注入依赖,而不是在初始化的时候就注入。
    • 缺点:不能将对象设为final。
  • 属性注入
    • 优点:简单,可读性高。
    • 缺点:可能导致循环依赖、重名依赖、依赖为空,被多方依赖的可能通过反射修改了内部的值。

Spring团队通常建议使用构造器来注入,因为它允许一个应用程序组件实现为不可变对象,并确保所需的依赖项不是空。此外构造器注入组件总是返回一个完全初始化状态的client客户端(调用)。不过需要注意的是,大量的构造函数参数是一个糟糕的代码习惯,这意味着类可能有太多的责任,应该被重构,以更好地解决适当的关注点分离。

而对于属性注入,还有两种方式注解方式:@Autowired@Resource,区别如下:

  • @Autowired注解由Spring提供;@Resource注解由J2EE提供
  • @Autowired按类型进行装配,当有多个相同类型的bean时则按名字进行装配;@Resource可以通过配置参数选择按类型或者名称进行装配,默认是通过名称

两者还有使用上的区别:

  • @Autowired默认情况下必须要求依赖对象存在,如果要允许null值,可以设置它的required属性为false。如果想使用名称装配可以结合@Qualifier注解进行使用。
  • @Resource默认按照名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行名称查找。如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。

如果使用属性注入的话,一般推荐使用@Resource注解,这样就不用写setter方法了,并且这个注解是属于J2EE的,减少了与Spring的耦合。

如果有兴趣了解更多相关内容,欢迎来我的个人网站看看:耶瞳空间

### 2025 Java面试题汇总与八股文集合 以下是针对2025年Java开发领域常见的面试题和知识点总结,涵盖了核心技术和框架相关内容: #### JVM基础 JVM作为Java运行的核心环境,在面试中占据重要地位。了解其内存模型、垃圾回收机制以及类加载过程是非常必要的[^1]。 - **GC调优**:掌握不同代的垃圾收集器及其工作原理,例如G1、ZGC等新型垃圾收集器的特点及适用场景。 - **堆外内存管理**:随着大数据处理需求增加,DirectByteBuffer的应用越来越广泛。 #### 并发编程 多线程与并发控制是现代Java应用的重要组成部分。以下是一些高频考点: - **Lock接口 vs synchronized关键字**:两者的主要区别在于灵活性和支持功能的不同[^2]。 - **AQS(AbstractQueuedSynchronizer)**:深入理解其实现原理对于设计自定义同步工具至关重要。 - 关于`wait()`、`notify()` 和 `notifyAll()` 方法为何定义在Object而非Thread中的原因已得到解释[^3]。 #### Spring生态体系 Spring家族产品几乎贯穿整个企业级解决方案架构之中。 - **IoC/DI容器基本概念**:如何通过配置文件或者注解方式完成依赖注入操作。 - **事务传播行为Transaction Propagation Behavior**:熟悉PROPAGATION_REQUIRED, PROPAGATION_REQUIRES_NEW等选项的具体含义。 - 微服务治理下的Spring Cloud组件选型依据分析。 #### 数据库技术栈 数据库交互层面的知识同样不可忽视。 - MySQL索引优化策略探讨;InnoDB存储引擎内部结构剖析。 - Redis数据类型介绍及时序图绘制技巧分享。 #### 中间件及其他分布式系统相关话题 消息队列如RabbitMQ,Kafka的工作模式对比研究; Hadoop生态系统概览——MapReduce,HDFS,YARN三驾马车详解。 ```java // 示例代码片段展示简单的生产者消费者模型实现 public class ProducerConsumerExample { private final BlockingQueue<Integer> queue; public ProducerConsumerExample(int capacity){ this.queue=new ArrayBlockingQueue<>(capacity); } public void produce(int value)throws InterruptedException{ while(true){ try{ queue.put(value); break; }catch(InterruptedException e){} } } public Integer consume()throws InterruptedException{ while(queue.isEmpty()){ Thread.sleep(100L); } return queue.take(); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值