Spring-关于注解开发

注解开发

1、什么是注解
(1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值…)
(2)使用注解,注解作用在类上面,方法上面,属性上面
(3)使用注解目的:简化xml配置

其中常用的注解如表所示
在这里插入图片描述

衍生注解

2、Spring针对Bean管理中创建对象提供注解
(1)@Component
(2)@Service
(3)@Controller
(4)@Repository

  • 上面四个注解功能是一样的,都可以用来创建bean实例

我们这些注解,就是替代了在配置文件当中配置步骤而已!更加的方便快捷!
@Component三个衍生注解

为了更好的进行分层,Spring可以使用其它三个注解,功能一样,目前使用哪一个功能都一样。
@Controller:web层
@Service:service层
@Repository:dao层

3、基于注解方式实现对象创建
第一步 引入依赖
在这里插入图片描述
第二步 开启组件扫描

 <!--开启组件扫描 1 如果扫描多个包,多个包使用逗号隔开 2 扫描包上层目录 --> 
 <context:component-scan base-package="com.atguigu">
 </context:component-scan>

第三步 创建类,在类上面添加创建对象注解

//在注解里面value属性值可以省略不写, 
//默认值是类名称,首字母小写
 //UserService -- userService
@Component(value = "userService") //<bean id="userService" class=".."/> 
public class UserService { 
public void add() {
 System.out.println("service add......."); 
 }
  }

4、开启组件扫描细节配置

<!--示例1 
use-default-filters="false" 表示现在不使用默认filter,自己配置filter
 context:include-filter ,设置扫描哪些内容 
 --> 
 <context:component-scan base-package="com.atguigu" use-default-filters="false"> 
 <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> 
 </context:component-scan> 

 <!--示例2 下面配置扫描包所有内容 context:exclude-filter: 
 设置哪些内容不进行扫描 
 -->
  <context:component-scan base-package="com.atguigu"> 
  <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> 
  </context:component-scan>

基于注解方式实现属性注入

属性注入的意思就是可以不用去new了。

(1)@Autowired:根据属性类型进行自动装配

第一步 把service和dao对象创建,在service和dao类添加创建对象注解
第二步 在service注入dao对象,在service类添加dao类型属性,在属性上面使用注解

@Service
 public class UserService { 
 //定义dao类型属性
  //不需要添加set方法
   //添加注入属性注解
    @Autowired 
    private UserDao userDao; 
    public void add() {
     System.out.println("service add......."); 
     userDao.add();
      } 
}

@Autowired(required=false) 说明:false,对象可以为null;true,对象必须存对象,不能为null。

(2)@Qualifier:根据名称进行注入

这个@Qualifier注解的使用,和上面@Autowired一起使用

 //定义dao类型属性 
 //不需要添加set方法
 //添加注入属性注解 
 @Autowired //根据类型进行注入 
 @Qualifier(value = "userDaoImpl1") //根据名称进行注入 
 private UserDao userDao;

@Autowired是根据类型自动装配的,加上@Qualifier则可以根据byName的方式自动装配

(3)@Resource:可以根据类型注入,可以根据名称注入

  • @Resource如有指定的name属性,先按该属性进行byName方式查找装配;
  • 其次再进行默认的byName方式进行装配;
  • 如果以上都不成功,则按byType的方式自动装配。
  • 都不成功,则报异常。
//@Resource 
//根据类型进行注入
@Resource(name = "userDaoImpl1") //根据名称进行注入
 private UserDao userDao;

(4)@Value:注入普通类型属性

@Value(value = "abc") 
private String name;

小结

@Autowired与@Resource异同:
1、@Autowired@Resource都可以用来装配bean。都可以写在字段上,或写在setter方法上。
2、@Autowired默认按类型装配(属于spring规范),默认情况下必须要求依赖对象必须存在,如果要允许null 值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称
装配可以结合@Qualifier注解进行使用
3、@Resource(属于J2EE复返),默认按照名称进行装配,名称可以通过name属性进行指定。如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。它们的作用相同都是用注解方式注入对象,但执行顺序不同。@Autowired先byType,@Resource先byName

完全注解开发

(1)创建配置类,替代xml配置文件

@Configuration  //作为配置类,替代xml配置文件
@ComponentScan(basePackages = {"com.atguigu"})
public class SpringConfig {

}

(2)编写测试类

@Test
    public void testService2() {
        //加载配置类
        ApplicationContext context
                = new AnnotationConfigApplicationContext(SpringConfig.class);
        UserService userService = context.getBean("userService", UserService.class);
        System.out.println(userService);
        userService.add();
    }

属性注入

使用注解注入属性
1、可以不用提供set方法,直接在直接名上添加@value(“值”)

@Component("user")
// 相当于配置文件中 <bean id="user" class="当前注解的类"/>
public class User {
@Value("秦疆")
// 相当于配置文件中 <property name="name" value="秦疆"/>
public String name;
}

2、如果提供了set方法,在set方法上添加@value(“值”);

@Component("user")
public class User {
public String name;
@Value("秦疆")
public void setName(String name) {
this.name = name;
}
}

@scope

singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。
prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收

@Controller("user")
@Scope("prototype")
public class User {
@Value("秦疆")
public String name;
}

小结

XML与注解比较

  • XML可以适用任何场景 ,结构清晰,维护方便
  • 注解不是自己提供的类使用不了,开发简单方便
    xml与注解整合开发 :推荐最佳实践
  • xml管理Bean
  • 注解完成属性注入
  • 使用过程中, 可以不用扫描,扫描是为了类上的注解

<context:annotation-config/>(驱动注册)

作用:

  • 进行注解驱动注册,从而使注解生效
  • 用于激活那些已经在spring容器里注册过的bean上面的注解,也就是显示的向Spring注册
  • 如果不扫描包,就需要手动配置bean
  • 如果不加注解驱动,则注入的值为null!

基于Java类进行配置

JavaConfig 原来是 Spring 的一个子项目,它通过 Java 类的方式提供 Bean 的定义信息,在 Spring4 的版本, JavaConfig 已正式成为 Spring4 的核心功能 。

测试:

1、编写一个实体类,Dog
@Component //将这个类标注为Spring的一个组件,放到容器中!
public class Dog {
public String name = "dog";
}

2、新建一个config配置包,编写一个MyConfig配置类

@Configuration //代表这是一个配置类
public class MyConfig {
@Bean //通过方法注册一个bean,这里的返回值就Bean的类型,方法名就是bean的id!
public Dog dog(){
return new Dog();
}
}

3、测试

@Test
public void test2(){
ApplicationContext applicationContext =
new AnnotationConfigApplicationContext(MyConfig.class);
Dog dog = (Dog) applicationContext.getBean("dog");
System.out.println(dog.name);
}

导入其他配置如何做呢?
1、我们再编写一个配置类!

@Configuration //代表这是一个配置类
public class MyConfig2 {
}

2、在之前的配置类中我们来选择导入这个配置类

@Configuration
@Import(MyConfig2.class) //导入合并其他配置类,类似于配置文件中的 inculde 标签
public class MyConfig {
@Bean
public Dog dog(){
return new Dog();
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值