使用注解开发

使用注解开发

spring4以后,使用注解开发,必须要保证aop的包导入了
使用注解需要导入context约束,增加注解支持

 <context:annotation-config/>
    <context:component-scan base-package="com.pyt"/>

@Component

bean和属性的注入:

@Component     //相当于<bean id="user" class="com.pyt.pojo.User"/>
public class User {
    @Value("pyt")
    private String name;

    public String getName() {
        return name;
    }

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

衍生的注解

@Component有几个衍生的注解,按照MVC三层架构分层如下:
dao @Repository
service @Service
controller @Controller
这四个注解功能一样,均代表将某个类注册到Spring中,装配Bean

作用域

Scope(“singleton” / “prototype”) 设置为单/多例模式

小结

xml与注解:
xml更加万能,适用于任何场合,维护简单方便
注解不是自己的类使用不了,维护相对复杂
xml与注解最佳实践:
xml用来管理bean
注解只负责完成属性的注入
使用过程中只需要注意:开启注解支持让注解生效;扫描包

全注解开发

使用java的方式配置Spring
JavaConfig是Spring的一个子项目,在spring4之后成为了核心功能。
MyConfig类
@Configuration也会被容器托管,注册到容器中,因为他本来就是一个@Component
@Configuration代表这是一个配置类,相当于之前的beans.xml

@Configuration
@ComponentScan("com.pyt")
public class MyConfig {
    /**
     * @Bean注册一个bean,相当于之前的一个bean标签
     * 该方法名相当于bean标签中的id
     * 返回值相当于bean标签的class属性
     * @return
     */
    @Bean
    public User getUser(){
        return new User();
    }

}

如果完全使用配置类的方式进行开发,我们只能通过AnnotationConfig上下文来获取容器,通过配置类的class对象加载。
获取容器(测试类):

public class MyTest {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(MyConfig.class);
        User user = context.getBean("getUser", User.class);
        System.out.println(user.getName());
    }
}

可以将多个配置类导入成为一个配置类

@Import(MyConfig2.class)
public class MyConfig {
    @Bean
    public User getUser(){
        return new User();
    }

}

纯java配置在SpringBoot中随处可见

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值