SpringBean的装配

SpringBean的生命周期
在bean的配置文件中
<bean class="com.dongmu.pojo.Hello" id="hello" name="hello2,hello3" scope="prototype">
        <constructor-arg type="java.lang.String" value="kksdmk"/>
        <constructor-arg type="java.lang.String" value="00"/>
    </bean>
scope可以指定创建的对象是否是单例的,如果不是单例的这个时候容器中会创建一个对象,我取一次它就会再创建一个,
prototype:原型模式
singleton:单例模式


三种装配的方式

1:xml中显示的配置
2:java中配置
3:引用类型的自动装配
	autowire:这个标签可以再bean的内部使用
		byName:按照名称自动装配,
		byType:按照类型自动装配,这个时候要求类型必须全局唯一
	注解:可以直接使用注解,要加入注解驱动<context:annotation-driven/>,别导错约束了,是mvc的约束
<context:annotation-config><context:component-scan>的区别
	<context:annotation-config> 是用于激活那些已经在spring容器里注册过的bean(无论是通过xml的方式还是通过package sanning的方式)上面的注解。
	<context:component-scan>除了具有<context:annotation-config>的功能之外,			
	<context:component-scan>还可以在指定的package下扫描以及注册javabean ,这个时候通过注解@Conponent指定名称(id),然后直接getbean就行了,不用再bean的配置文件里面注册。

	另外,Spring 还提供了 3 个创建对象的注解:
	➢ @Repository 用于对 DAO 实现类进行注解
	➢ @Service 用于对 Service 实现类进行注解
	➢ @Controller 用于对 Controller 实现类进行注解
	这三个注解与@Component 都可以创建对象,但这三个注解还有其他的含义,@Service
	创建业务层对象,业务层对象可以加入事务功能,@Controller 注解创建的对象可以作为处
	理器接收用户的请求。
	@Repository,@Service,@Controller 是对@Component 注解的细化,标注不同层的对
	象。即持久层对象,业务层对象,控制层对象。
	@Component 不指定 value 属性,bean 的 id 是类名的首字母小写。
	这几个注解还可以联合@Scope使用指定是单例的还是原型模式
	
几个注解的使用:
	@aruowired(required = "boolean")按照类型注入
	required指定没有的时候是报错还是为null
	还可以和@Qualifier联合使用指定匹配的id

	Spring提供了对 jdk中@Resource注解的支持。@Resource 注解既可以按名称匹配Bean,
	也可以按类型匹配 Bean。默认是按名称注入。@Resource 注解若不带任何参数,采用默认按名称的
	方式注入,按名称不能注入 bean, 则会按照类型进行 Bean 的匹配注入。@Resource 注解指定其 
	name 属性,则 name 的值即为按照名称进行匹配的 Bean 的 id。但是这个时候就不会再按类型匹配
	了,找不到就会报错。
	由于使用注解,底层用到是反射,所以连set方法也不用写了。

下面说一下上面说的第二种方式java中配置
1:实体类

package com.dongmu.pojo;


import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

//@Component
public class User {
    @Value("DONGMU")
    String name;

    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                '}';
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public User() {
    }

    public User(String name) {
        this.name = name;
    }
}

2:Java类用作配置文件

package com.dongmu.config;

import com.dongmu.pojo.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan("com.dongmu.pojo")
public class DongmuConfig {
    @Bean
    User getUser(){
        return new User();
    }
}

3:使用方式

import com.dongmu.config.DongmuConfig;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class Test {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(DongmuConfig.class);
        System.out.println(context.getBean("getUser"));
    }
}

当然我们还可以引入两个配置类,使用@Import注解导入其他的配置类
在这里插入图片描述

在这里插入图片描述
其实SpringBoot底层也是使用这种配置方式实现的,所以我们以后用SpringBoot不需要配置的文件实际上是人家底层已经配置好了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北海冥鱼未眠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值