bean.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"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd"> <!--告知spring在创建容器时要扫描的包,配置所需要的标签不是在beans的约束中,而是一个名称为
context名称空间和约束-->
<context:component-scan base-package="cn.flypig666"></context:component-scan> </beans>

* 曾经XML的配置:
* <bean id="acountService" class="cn.flypig666.service.impl.AccountServiceImpl"
* scope = "" init-method="" destroy-methods="">
* <property name="" value="" | ref = "" ></property>
* </bean>
* 用于创建对象的
* 他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能是一样的
* @Component:
* 作用:用于把当前类对象存入spring容器中
* 属性:
* value:用于指定bean的id。当我们不写时,它的默认值是当前类名,且首字母改小写
* Controller:一般用在表现层
* Service:一般用于业务层
* Repository:一般用在持久层
* 以上三个注解他们的作用和属性于Component是一模一样的
* 他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰
*
*
* 用于注入数据的
* 他们的作用就和在XML配置文件中的bean标签中写一个<property>标签的作用是一样的
* Autowired:
* 作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
* 如果IOC容器中没有任何bean的类型和要注入的变量类型匹配,则报错
* 如果IOC容器中有多个类型匹配时:
* 出现位置:
* 可以是变量上,也可以是方法上
* 细节:
* 在使用注解注入时,set方法就不是必须的了
* Qualifier:
* 作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入时不能单独使用,但是在给方法参数注入时可以
* 属性:
* value:用于指定注入bean的id
* Resource
* 作用:直接按照bean的id注入。它可以独立使用
* 属性:
* name:用于指定bean的id
* 以上三个注入都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现
* 另外,集合类型的注入只能通过XML来实现
*
* Value
* 作用:用于注入基本类型和String类型的数据
* 属性:
* value:用于指定数据的值。它可以使用spring中SpEL(也就是spring的el表达式)
* SpEL的写法:${表达式}
* 用于改变作用范围的
* 他们的作用就和在bean标签中使用scope属性实现的功能是一样的
* Scope
* 作用:用于指定bean的作用范围
* 属性:
* value:指定范围的取值。常用取值:singleton prototype(默认singleton)
* 和生命周期相关 了解
* 他们的作用就和在bean标签中使用init-method和destroy-methode的作用是一样的
* PreDestroy
* 作用:用于指定销毁方法
* PostConstruct
* 作用:用于指定初始化方法
 @Service("accountService")
public class AccountServiceImpl implements IAccountService { // @Autowired
// @Qualifier("accountDao1")
@Resource(name = "accountDao1")
private IAccountDao accountDao2 =null; public AccountServiceImpl(){ System.out.println("service对象创建了");
} public void saveAccount(){
accountDao2.saveAccount();
} @PostConstruct
public void init(){
System.out.println("对象初始化了.....");
} @PreDestroy
public void destory(){
System.out.println("对象销毁了.....");
}
}
												

最新文章

  1. centos 防火墙
  2. ubuntu 12.10 sourcelist软件更新源列表(zz)
  3. iOS之NSString类中compare方法的陷阱
  4. MFC List Control 控件添加单元格编辑,实现可编辑重写
  5. 作业,备份,存储过程,sqlserver print 语句,输出字符串
  6. Oracle存储过程基本语法 存储过程
  7. Elsevier期刊网上投稿指南
  8. C的结构体使用
  9. dtp--eclipse的安装数据源管理的一个插件的安装方法
  10. Android开发UI之Notification
  11. UVa465 - Overflow
  12. Action
  13. 响应式设计:理解设备像素,CSS像素和屏幕分辨率
  14. UVA 439 Knight Moves(BFS)
  15. svn服务器的搭建与使用二
  16. github第一次引用开源的库
  17. 无序hashset与hashmap让其有序
  18. Python Mock的入门(转)
  19. hdu-6301-贪心
  20. 具体解释Ajax技术

热门文章

  1. 20180713NOIP模拟赛
  2. Java-Class-@I:org.junit.Test
  3. 如何再windows里面装Tableau Server
  4. git学习记录1(本地库管理)
  5. 关于double的输入输出
  6. day 87 DjangoRestFramework学习一之restful规范、APIview、解析器组件、Postman等
  7. Codeforces 1167D - Bicolored RBS
  8. 20140425 malloc和new不同 dynamic何时返回0
  9. 金三银四铜五铁六,Offer收到手软!
  10. Substring UVA - 11468 AC自动机+概率DP