public class Blog {
private String name;
public Blog(){}
public Blog(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return “Blog{” +
“name='” + name + ‘’’ +
‘}’;
}
}
第三步 编写XML文件
在resources目录下编写bean1.xml文件:
<?xml version="1.0" encoding="UTF-8"?><beans xmlns=“http://www.springframework.org/schema/beans”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
第四步 编写测试方法
@Test
public void test(){
//解析beans.xml文件 , 生成管理相应的Bean对象
ApplicationContext context = new ClassPathXmlApplicationContext(“bean1.xml”);
//getBean : 参数即为spring配置文件中bean的id .
Blog blog = (Blog) context.getBean(“blog”);
System.out.println(blog);
}
运行结果:
看到这里的输出,就说明成功了。
2.控制反转与依赖注入
===========
看到以上的程序,我们来思考两个问题。
1、Blog对象是谁创建的?
答:Spring创建的。
2、Blog对象的属性是怎么进行设置的?
答:由Spring容器设置的。
通过这两个问题,我们知道我们把对象的创建和对象之间的调用交给了Spring进行管理,而这个过程就是控制反转(IOC)。
-
控制 : 谁来控制对象的创建 , 传统应用程序的对象是由程序本身控制创建的 , 使用Spring后 , 对象是由Spring来创建的
-
反转 : 程序本身不创建对象 , 而变成被动的接收对象 .
依赖注入:利用set方法来进行注入的,故在写实体类时切记要有set方法。
3.加载过程
======
3.1 BeanFactory与ApplicationContext的概念
Spring提供IOC容器实现两种方式:(两个接口)
(1)BeanFactory:IOC容器基本实现,是Spring内部的使用接口,不提供开发人员进行使用
* 加载配置文件时候不会创建对象,在获取对象(使用)才去创建对象
(2)ApplicationContext:BeanFactory接口的子接口,提供更多更强大的功能,一般由开发人员进行使用
* 加载配置文件时候就会把在配置文件对象进行创建
(3)ApplicationContext接口有实现类
3.2三者功能
1、BeanFactory:IOC容器的基本实现(不常用)
作用:
①.配置,创建以及管理Bean对象;
②.维护Bean之间的依赖关系;
③.负责Bean对象的生命周期
2、ApplicationContext(应用上下文)
提供了更多的高级特性,是BeanFactory的子接口(更加常用),在初始化上下文时就实例化所有单例的 Bean。
作用:
①.读取Bean定义文件;
②.维护Bean之间的依赖关系;
③.国际化的支持;
④.资源访问;
⑤.事件传播;
⑥多配置文件加载
3、实现类:
ClassPathXmlApplicationContext——从类路径下的XML配置文件中加载上下文定义,把应用上下文定义文件作为类资源;
FileSystemXmlApplicationContext——读取文件系统下的XML配置文件并加载上下文定义;
3.3 关系图
BeanFactory与ApplicationContext的关系:
ApplicationContext与实现类的关系:
三者的关系理解到这里就可以了,来看我们程序的第一段代码:
ApplicationContext context = new ClassPathXmlApplicationContext(“bean1.xml”);
这行代码就是通过ClassPathXmlApplicationContext从类路径下的XML配置文件中加载上下文定义,创建一个ApplicationContext 的Spring 容器,生成管理相应的Bean对象,因为ApplicationContext能够读取Bean定义文件,并获取相应的Bean对象。
context.getBean(“blog”);
最后,一心同学扔出一张图,加深大家对整个运行过程的理解:
看到这里相信就会对Spring对程序的运行过程有了大概的了解,如果想要深入了解IOC的运行原理,可以去网上查看更加详细的信息,由于本篇博客只是为大家讲解Spring的简单使用和概念的理解,这里就不再花大量的篇幅去讲解IOC的具体运行原理。
结语
对Spring的搭建完成,以及对基本概念有了一定的理解,就可以进入下一个阶段了,一心同学将会在下一篇博客讲解Spring中的Bean管理机制。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/5954316248698aa274abb0f56f16e15e.jpeg)
最后总结
ActiveMQ+Kafka+RabbitMQ学习笔记PDF
关于分布式,限流+缓存+缓存,这三大技术(包含:ZooKeeper+Nginx+MongoDB+memcached+Redis+ActiveMQ+Kafka+RabbitMQ)等等。这些相关的面试也好,还有手写以及学习的笔记PDF,都是啃透分布式技术必不可少的宝藏。以上的每一个专题每一个小分类都有相关的介绍,并且小编也已经将其整理成PDF啦
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
[外链图片转存中…(img-cYkcWhKI-1713497700597)]
关于分布式,限流+缓存+缓存,这三大技术(包含:ZooKeeper+Nginx+MongoDB+memcached+Redis+ActiveMQ+Kafka+RabbitMQ)等等。这些相关的面试也好,还有手写以及学习的笔记PDF,都是啃透分布式技术必不可少的宝藏。以上的每一个专题每一个小分类都有相关的介绍,并且小编也已经将其整理成PDF啦
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!