博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Spring 依赖注入
阅读量:6216 次
发布时间:2019-06-21

本文共 1158 字,大约阅读时间需要 3 分钟。

每一个基于java的应用程序都有一个共同工作来展示给用户看到的内容作为工作的应用几个对象。当编写一个复杂的Java应用程序,应用程序类应该尽可能独立其他Java类来增加重复使用这些类,并独立于其他类别的测试它们,而这样做单元测试的可能性。依赖注入(或有时称为布线)有助于粘合这些类在一起,同时保持他们的独立。

6a81825d9297c8da86ee4c8094000bc233e79be1

考虑有其中有一个文本编辑器组件的应用程序,要提供拼写检查。标准的代码将看起来像这样:

 
public
class
TextEditor
{
private
SpellChecker
spellChecker
;
public
TextEditor
()
{
spellChecker
=
new
SpellChecker
();
}
}

我们在这里所做的就是创建文本编辑和拼写检查之间的依赖性。在控制方案中的反转,我们反而会做这样的事情:

 
public
class
TextEditor
{
private
SpellChecker
spellChecker
;
public
TextEditor
(
SpellChecker
spellChecker
)
{
this
.
spellChecker
=
spellChecker
;
}
}

ee9e6941b5cb6321e453efdff783dcda956341f5

在这里,文本编辑不应该担心拼写检查落实。拼写检查器将独立实施,将提供给文本编辑在文本编辑实例化的时候,这整个过程是由Spring框架的控制。

在这里,我们已经删除从文本编辑的全面控制,并保持它在其他地方(即XML配置文件)和依赖性(即类拼写检查)被注入到类文本编辑通过类构造函数。因此,流程控制已经“倒”通过依赖注入(DI),因为已经有效地委派依赖一些外部系统。

依赖注入的第二种方法是通过文本编辑类,我们将创建拼写检查实例的setter方法,该实例将被用来调用setter方法来初始化文本编辑的属性。

因此,DI主要有两种变体和下面的两个子章将涵盖两者结合实例:

S.N. 依赖注入类型及说明
1 基于构造函数的依赖注入
当容器调用类的构造函数有多个参数,每个代表在其他类中的构造函数依赖关系为基础的DI来完成。
2 基于setter方法的依赖注入
基于setterDI由容器调用setter方法对你的bean调用无参构造器或无参static工厂方法实例化bean之后完成的。

你可以混合两种,构造型和基于setter方法DI,但它是拇指使用构造函数的参数进行强制依赖和setter可选依赖的一个很好的规则。

代码是清洁器与DI原理,当对象被提供有它们的依赖性的去耦效果更明显。对象不查询它的依赖,以及不知道的依赖性的位置或类,而一切都由Spring框架关照。

原文发布时间为:2018-10-20
本文来自云栖社区合作伙伴“ ”,了解相关信息可以关注“ ”。

转载地址:http://vslja.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
JDBC的事务
查看>>
Linux软连接和硬链接(摘录)
查看>>
30分钟让你学会 Spring事务管理属性
查看>>
contextlib
查看>>
android动画研究
查看>>
2016弱校联萌十一专场10.3 遗憾题合集
查看>>
linux服务器CPU参数/proc/cpuinfo
查看>>
arcgis api for js简要笔记
查看>>
huffman树即Huffma编码的实现
查看>>
haystack+Elasticsearch搜素引擎
查看>>
Linux内核数据结构
查看>>
算法第二章上机实践报告
查看>>
译文——The habits of highly successful people
查看>>
UEFI系统安装U盘的制作方式
查看>>
读《Oracle DBA工作笔记》知识点-获取创建语句
查看>>
Idea改项目名
查看>>
Io流的概述
查看>>
【6】使用nginx
查看>>
WPF: 在MVVM中使用Navigtaion
查看>>