在Spring中,主要用于管理bean的注解分为四大类:1.用于创建对象。2.用于给对象的属性注入值。3.用于改变作用的范围。4.用于定义生命周期。这几个在开发中经常接触到,也可以说每天都会遇见。其中创建对象是重点,Spring中创建对象的有四个:分别是@Component,@Controller,@Service,@Repository。对于@Component注解:把资源让Spring来管理,相当于xml中的配置的Bean。属性:value:指定Bean中的id。如果不指定value属性,默认Bean的id是当前类的类名,首字母小写。在开发中的场景是这样的,其实是在实现类中加入即可:

@Component("customerService")
public class CustomerServiceImpl implements CustomerService{ public void save() {
System.out.println("顾客保存方法");
}
}

而其它的三个注解都是针对一个衍生注解,它们的作用及属性都是一模一样的。只不过提供了更加明确的语义化。@Controller:一般用于表现层的注解。@Service:一般用于业务层的注解。@responsitory:一般用于持久层的注解。用法与以上相同,这里不做过多的解释。要理解这个三个注解就是让标注类本身的用途清晰而已。接下来,聊聊用于给对象的属性注入值得问题。Spring给我们提出了注入数据的注解有:@Value,@Autowired,@Qualifier,@Resource。其中@Value:注入基本数据类型和String类型数据,它的属性value用于指定值。@Autowired这个用法是比较重要的,它能够自动按照类型注入。当使用注解注入属性时,set方法可以省略。它只能注入其他Bean类型。当有多个类型匹配时,使用要注入的对象变量名称作为Bean的id,在Spring容器中查找,找到了也可以注入成功,找不到就报错。这句话是不是很难理解。其实所表达的意思是这样的,这个注解的是自动注入的意思,写注入的对象,这个对象就是Bean中的id,让Spring自己去查找,找到说明可以用,找不到则报错。

代码如下:

@Service("customerService")
public class CustomerServiceImpl implements CustomerService{ @Value(value="jack")
private String name; @Autowired
private UserDao userdao; public void save() {
System.out.println("顾客保存方法---"+name); userdao.save();
}
}

@Qualifier:官方是这样介绍的,在自动按照类型的基础上,再按照Bean的id注入。它在给字段注入时不能独立使用,必须和@Autowired一起使用,但是给方法参数注入时,可以独立使用。属性:指定Bean的id。应用场景:如果一个接口有两个设置多个实现类,如果对其注入的话,优先会注入与Bean的id与属性名一样的Bean,如果像注入指定的Bean,则需要用@Qualifier注解名字注入。而@Resource:直接按照Bean的id注入,它只能注入其它的Bean类型。属性:name指定Bean的id。

@Service("customerService")
public class CustomerServiceImpl implements CustomerService{ @Autowired
@Qualifier("userDao2")
private UserDao userdao; /*
@Resource(name="userDao2"); //@Resource注解的使用
   private userDao userdao;
*/
public void save() {
System.out.println("顾客保存方法---"+name);
userdao.save();
}
}

用于改变作用域范围的@Scope:指定Bean的作用范围。属性:value指定范围的值。默认是单例的,如果像设置为多列的,只需在类中加@Scope("prototype"),具体代码详见如下:

@Service("customerService")
@Scope("prototype")
public class CustomerServiceImpl implements CustomerService{
................
}

用于生命周期相关的注解,@PostConstruct注解,加在方法上指定Bean对象创建好之后,调用该方法初始化对象,类似于xml的init-method方法。@PreDestroy注解,指定Bean销毁之前,调用该方法,类似与xml的destroy-method方法。注意的是如果你要想看当前的效果,就必须要调用ClassPathXmlApplicationContext.close( )方法,同时scope的值要是singleton。是在销毁之前执行。

    @PostConstruct
public void firstInit(){
System.out.println("第一个执行");
} public void save() {
System.out.println("顾客保存方法---"+name);
userdao.save();
} @PreDestroy
public void lastdestroy(){
System.out.println("最后一个执行");
}

对于以上和之前写的文章,关于xml和注解各有各的优势。注解的话就是配置简单,维护方便。而xml的优势是修改时,不用改源代码,不涉及重新编译和部署。

最新文章

  1. 测试的程序 test.php,保存放IIS的根目录下
  2. HDU 1029 Ignatius and the Princess IV --- 水题
  3. InnoDB Double write
  4. Oracle 多实例如何通过EM进行访问-portlist.ini
  5. Android 获取信号强度
  6. Apple 公司开发者账号注册
  7. java.lang.ClassCastException
  8. ural 1932 The Secret of Identifier 容斥
  9. 内置Web Server
  10. java equals和tostring
  11. 时序数据库InfluxDB:简介及安装
  12. #WEB安全基础 : HTTP协议 | 文章索引
  13. ltp-ddt git
  14. java设计模式之单例模式以及实现的几种方法
  15. RMQ问题 [luogu 3865]
  16. Android 判定手机是否root
  17. python eric6 IDE
  18. opencv学习之路(2)、读取视频,读取摄像头
  19. 【git】如何向gitHub上推送自己的项目
  20. do_something方法解析

热门文章

  1. iOS开发之--蓝牙开发实战
  2. Eclipse修改背景颜色
  3. Poj1482
  4. ajax 传递数组类型参数后台接收不到的问题
  5. Django设置中文,和时区、静态文件指向
  6. java File delete() 失败,又没有报错。
  7. shell脚本读取文件+读取命令行参数+读取标准输入+变量赋值+输出到文件
  8. 阻塞IO 非阻塞IO 异步IO
  9. 前端基础-css(3)
  10. [设计模式]访问者 Visitor 模式