HelloSpring
咱们要想应用Spring,首先必定要先导入其jar包,咱们只须要在maven配置文件中退出相应的依赖,就会主动下载相应的依赖项,
<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.0.RELEASE</version>
</dependency>
编写代码
编写一个Hello实体类
public class Hello {
public String str;
public String getStr() {
return str;
}
public void setStr(String str) {
System.out.println("set");
this.str = str;
}
@Override
public String toString() {
return "Hello{" +
"str='" + str + '\'' +
'}';
}
}
编写Spring文件,命名为beans.xml
配置元数据通常有两种办法:
- 基于注解的配置:基于XML的配置元数据将这些bean配置为<bean/>
- 基于Java的配置:应用@Bean在@Configuration类中应用带注解的办法。
这里介绍 是基于注解的配置
<?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">
<!--应用spring来创建对象-->
<bean id="hello" class="com.zhonghu.pojo.Hello">
<!--
value:具体的值
ref:援用Spring容器中曾经创立好的对象。
-->
<property name="str" value="Spring"/>
</bean>
</beans>
其中这里的id是标识单个bean定义的字符串;class是定义Bean的类型并应用齐全限定的类名。
实例化容器
实例化容器能够通过Spring提供的ApplicationContext构造函数。其通过一个或多个参数来从各种内部资源中加载配置元数据Classpath。
@Test
public void test(){
//解析beans.xml文件 , 生成治理相应的Bean对象
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
//getBean : 参数即为spring配置文件中bean的id .
Hello hello = (Hello) context.getBean("hello");
// Hello hello = context.getBean("hello",Hello.class);
System.out.println(hello.toString());
}
后果以及总结
- 后果
- 总结
-
- 在后果中咱们能够很清晰的看到,其调用了set办法,也就是说set办法是实现Ioc的根底。
- Hello对象是谁创立的?——是Spring创立的
- Hello对象的属性是怎么设置的?——hello对象的属性是由Spring容器实现的。
- 这个过程就是管制反转:
-
- 管制:谁来管制对象的创立,传统应用程序是程序员来管制创立的,应用spring后,对象是由spring来创立的
- 反转:程序自身不创建对象,而是变为被动承受对象
- 依赖注入:就是利用set办法来进行注入的
用这种办法后,咱们就不须要再程序中进行批改,要实现不同的操作,只须要在xml配置文件中进行批改即可。
所谓的IOC就是:对象由Spring来创立、治理、拆卸
IOC创建对象形式
通过无参构造方法来创立
User.java
public class User {
private String name;
public User() {
System.out.println("user无参构造方法");
}
public void setName(String name) {
this.name = name;
}
public void show(){
System.out.println("name="+ name );
}
}
beans.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">
<bean id="user" class="com.zhonghu.pojo.User">
<property name="name" value="zhonghu"/>
</bean>
</beans>
测试
@Test
public void test(){
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
//在执行getBean之前, user曾经创立好了 , 通过无参结构
User user = (User) context.getBean("user");
//调用对象的办法 .
user.show();
}
后果
能够发现,在调用show办法前,User对象就曾经通过无参结构初始化了。容器在创立的时候就曾经创建对象了。
Spring通过无参结构来创建对象,而后用set办法进行注入。
其name属性是类中的成员属性
通过有参构造方法来创立
UserT.java
public class UserT {
private String name;
public UserT(String name) {
this.name = name;
}
public void setName(String name) {
this.name = name;
}
public void show(){
System.out.println("name="+ name );
}
}
beans.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">
<!-- 第一种依据参数名字来设置-->
<bean id="userT" class="com.zhonghu.pojo.UserT">
<!-- name 指参数名-->
<constructor-arg name="name"value="zhonghu"/>
</bean>
<!-- 第二种根骨index参数下标来设置-->
<bean id="userT" class="com.zhonghu.pojo.UserT">
<!-- index值构造方法,下标从0开始 -->
<constructor-arg index="0" value="zhonghu"/>
</bean>
<!-- 第三种 依据参数类型设置 非常不举荐-->
<bean id="useT"class="com.zhonghu.pojo.UserT">
<constructor-arg type="java.lang.String" value="zhonghu"/>
</bean>
</beans>
测试
@Test
public void testT(){
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
UserT user = (UserT) context.getBean("userT");
user.show();
}
总结
在配置文件加载的时候。其中治理的对象都曾经初始化了
其name属性外面对应有参结构的形参名称
Spring的Bean在什么时候被实例化
应用BeanFactory作为工厂类
所有的Bean都是在第一次应用该Bean的时候初始化(懒加载)
应用ApplicationContext作为工厂类
- 如果bean的scope是singleton的,并且lazy-init为false(默认是false,所以能够不必设置),则ApplicationContext启动的时候就实例化该Bean,并且将实例化的Bean放在一个map构造的缓存中,下次再应用该Bean的时候,间接从这个缓存中取
- 如果bean的scope是singleton的,并且lazy-init为true,则该Bean的实例化是在第一次应用该Bean的时候进行实例化
- 如果bean的scope是prototype的,则该Bean的实例化是在第一次应用该Bean的时候进行实例化
Spring的配置
别名
alias 为bean设置别名,能够同时设置多个别名
<!--设置别名:在获取Bean的时候能够应用别名获取-->
<alias name="userT" alias="userNew"/>
Bean的配置
<!--bean就是java对象,由Spring创立和治理-->
<!--
id 是bean的标识符,要惟一,如果没有配置id,name就是默认标识符
如果配置id,又配置了name,那么name是别名
name能够设置多个别名,能够用逗号,分号,空格隔开
如果不配置id和name,能够依据applicationContext.getBean(.class)获取对象;
class是bean的全限定名=包名+类名
-->
<bean id="hello" name="hello2 h2,h3;h4" class="com.zhonghu.pojo.Hello">
<property name="name" value="Spring"/>
</bean>
import
个别用于团队开发,能够将多个配置文件导入合并为一个。
<import resource="{path}/beans.xml"/>
总结
- IOC创建对象的形式
-
- 无参结构:其name属性是类中的成员属性
- 有参结构:其name属性外面对应有参结构的形参名称
- Spring Bean在什么时候初始化
-
- 应用BeanFactory作为工厂类
-
-
- 所有的Bean都是在第一次应用该Bean的时候初始化(懒加载)
-
-
- 应用ApplicationContext作为工厂类
-
-
- 如果bean的scope是singleton的,并且lazy-init为false(默认是false,所以能够不必设置),则ApplicationContext启动的时候就实例化该Bean,并且将实例化的Bean放在一个map构造的缓存中,下次再应用该Bean的时候,间接从这个缓存中取
- 如果bean的scope是singleton的,并且lazy-init为true,则该Bean的实例化是在第一次应用该Bean的时候进行实例化
- 如果bean的scope是prototype的,则该Bean的实例化是在第一次应用该Bean的时候进行实例化
-
最初
- 如果感觉看完有播种,心愿能给我点个赞,这将会是我更新的最大能源,感激各位的反对
- 欢送各位关注我的公众号【java冢狐】,专一于java和计算机基础知识,保障让你看完有所播种,不信你打我
- 如果看完有不同的意见或者倡议,欢送多多评论一起交换。感激各位的反对以及厚爱。
欢送关注公众号“ Java冢狐”,获取最新消息
发表回复