博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
带你细嚼慢咽Spring框架,穿着红内裤带着梦想往前踏,详解IOC
阅读量:2503 次
发布时间:2019-05-11

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

背景 :

Spring框架一种轻量级开源框架。核心是以IOC(控制反转)和AOP(面向切面编程),同时也能与其他第三方框架进行无缝连接。

在这里插入图片描述

Spring的特点 :

非侵入式 :

概念–基于Spring开发的应用中的对象可以不依赖于Spring的API
控制反转 :
概念–将对象的创建和销毁交给Spring管理,调用者不必再创建对象
说白了–在没有spring之前,开发者需要自己去创建和销毁对象,而用了 spring,这些都交给了spring框架,不必再去亲手创建和销毁。
面向切面编程 AOP:
概念–面向切面编程是面向对象中的一种方式。在代码执行过程中,动态嵌入其他代码,叫做面向切面编程。
说白了–在运行时,动态的将代码切入到类的指定方法的指定位置上,这种思想就是面向切面的编程思想。
依赖注入 :
概念–对象不需要手动调用set()方法,而是直接通过配置文件/注解赋值,更简洁简便。
说白了–以前我们调用对象赋值是通过set()方法,spring一开始推出是配置文件(applicationContext.xml)通过来赋值,后面觉得变量多了标签太多不便于管理推出了注解的形式。
组件化 :
概念–用简单的组件配置组合成一个复杂的应用。Spring中提供注解和XML文件组合这些对象。
一站式 :
概念–在IOC和AOP的基础上可以整合各种企业应用的开源框架和优秀的第三方类库(实际上Spring 自身也提供了表述层的SpringMVC和持久层的Spring JDBC)。

IOC的控制反转和依赖注入

控制反转

举个简单的栗子

我想要一个女朋友,以前的正常逻辑就是找一个对得上眼的女生(记住这个找女生的过程),然后慢慢的了解她的爱好等等等等等等所有过程都需要自己去操作(这些放在Java类就是这个对象的方法,需要有这个对象才可以调用这些方法,传统方式就是要调用者自己创建对象),然而!!!后来有了各种相亲网站,你只要登录注册,填入信息后就可以得到各种女生的信息(得到对象,也就是这个对象不必你去找,人家已经给你提供好了),然后进行你的恋爱操作(方法),那么Spring在这个过程中充当的就是相亲网站,你可以在里面找到你需要的对象,然后进行对象的各种操作,这个就是Spring起到的作用,让调用者不必再去考虑对象如何创建,只管知道如何调用就好,但是Spring的前提就是,调用者本身也要交给Spring管理,就像你在相亲网相亲,不能说一个相亲网都不知道你任何信息情况下就让你在他们相亲网上相亲吧?也就是说,你本身的信息也要录入他们的网站。

简单一句话 : 用Spring之后不再有对象的new操作,所有new操作都交给Spring

依赖注入

简单一句话 : 创建被调用者实例的工作通常由Spring容器来完成,然后注入调用者,因此也称为依赖注入。

不管是依赖注入,还是控制反转,都说明Spring采用动态、灵活的方式来管理各种对象。对象与对象之间的具体实现互相透明。在理解依赖注入之前,再举个简单的栗子 :

在原始社会中,我需要吃菜,我可能需要自己去辛勤的劳动之后才能够吃上青菜,以此来看对应在Java中,就是需要什么对象就new什么对象,调用者需要亲手new所有的被调用者

随着社会进步,货币时代来临,吃青菜的人不必都要去种菜,在需要吃青菜的时候去跟卖/种青菜的人说,人家就会给你青菜,这整个过程中,吃青菜的人不必去关心青菜是如何耕种的,对应在Java中,这就是简单工厂设计模式

再来到现代的社会,需要青菜的人不必亲历亲为地去市场买菜,只需要在家里叫个外送就可以让别人将青菜送上门来,这里这种模式对应的就是Java中的***依赖注入***

扯了这么多可能还是有很多人看不懂,我再详细介绍一下以上三种情况 :

第一种情况 : Java的实例化调用者创建被调用的Java实例化对象,这种环境下会出现Java实例化对象出现在调用者的代码中,无法达到低耦合的目的

第二种情况 : 调用者不必考虑被调用者具体实现的过程,只要找到符合某个接口的实例,就可以创建使用,此时调用的代码面向接口,可以让调用者和被调用者解耦

第三种情况 : 当程序运行到需要被调用者时,spring自动生成一个实例给你使用,前提是调用者和被调用者都要被spring管理,依赖关系由spring提供

🆗下一部分是依赖注入的两种情况

设值注入
设值注入是通过setter方法传入被调用者的实例,这种注入方式比较简单,所以博主用的比较多的也是这种方式

给大家看一哈简单的代码 :public interface  People{
public void eatvege();//吃青菜}以下是蔬菜接口public interface Vege{
public void getnutrition();//获取营养的方法} people吃菜获取营养的实现类@Service("people")//这个注解得意思是将这个类交给spring管理public class PeopleImpl implements People{
@Autowired //这个注解的意思是注入值 private Vege ve;//面向接口 public PeopleImpl(){
}//构造方法 //设值注入所需的setter方法 public void setVe(Vege ve){
this.ve=ve; } //实现People接口的eatvege()方法 public void eatvege(){
System.out.println(ve.getnutrition()); }}

依赖注入(基于注解)的介绍

开发中 : 使用注解取代xml配置文件

@Component取代了标签
@Component(“id”)取代了
在web开发中提供了基于@Compontent的衍生注解方式(其功能都是一样的 ,只是为了有利于开发者区别)
@Repository : dao层
@Service : service层
@Controller : web层
以上注解可以理解为将类交给spring管理,一般都是写在类上面

依赖注入

给私有字段设值,也可以给setter方法设值
普通值一种方式 : @Value(" ")
引用值 :
第一种方式 --按照类型注入
@Autowired
第二种方式 --按照名称注入 两个注解混合使用
@Autowired
@Qualifier(“名称”)
第三种方式 --按照名称注入 一个注解
@Resource(“名称”)

生命周期

初始化 : @PostConstruct
销毁 : @PreDestroy

作用域

@Scope(“prototype”) 将spring的管理方式改为多例,因为spring默认是单例模式

注解使用的前提,必须添加命名空间,让Spring扫描含有注解类

在这里插入图片描述

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

你可能感兴趣的文章
Hadoop基础学习:基于Hortonworks HDP
查看>>
为什么linux安装程序 都要放到/usr/local目录下
查看>>
Hive安装前扫盲之Derby和Metastore
查看>>
永久修改PATH环境变量的几种办法
查看>>
大数据学习之HDP SANDBOX开始学习
查看>>
Hive Beeline使用
查看>>
Centos6安装图形界面(hdp不需要,hdp直接从github上下载数据即可)
查看>>
CentOS7 中把yum源更换成163源
查看>>
关于yum Error: Cannot retrieve repository metadata (repomd.xml) for repository:xxxxxx.
查看>>
linux下载github中的文件
查看>>
HDP Sandbox里面git clone不了数据(HTTP request failed)【目前还没解决,所以hive的练习先暂时搁置了】
查看>>
动态分区最佳实践(一定要注意实践场景)
查看>>
HIVE—索引、分区和分桶的区别
查看>>
Hive进阶总结(听课总结)
查看>>
大数据领域两大最主流集群管理工具Ambari和Cloudera Manger
查看>>
Sqoop往Hive导入数据实战
查看>>
Mysql到HBase的迁移
查看>>
Sqoop import进阶
查看>>
Hive语句是如何转化成MapReduce任务的
查看>>
Hive创建table报错:Permission denied: user=lenovo, access=WRITE, inode="":suh:supergroup:rwxr-xr-x
查看>>