注解:代码中的特殊标记,注解可以使用在类、方法、属性上面,使用注解可实现一些基本的功能。注解的写法是@注解名称(属性=属性值)
。
使用注解创建对象
第一步,创建Web项目,引入Spring的开发包
第二步,编写相关的类
在src目录下创建一个cn.itcast.anno包,并在该包下编写一个User类。
public class User {
public void add() {
System.out.println("add....................");
}
}
第三步,创建Spring配置文件
- 在Spring配置文件中引入约束,如下:
<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配置文件中做些事情,即开启注解扫描。
<!-- 开启注解的扫描。到配置的包里面扫描类、方法、属性上面是否有注解 -->
<context:component-scan base-package="cn.itcast"></context:component-scan>
注意:也可以这样开启注解扫描,如下:
<context:annotation-config></context:annotation-config>
但是这种开启注解扫描的方式,只会扫描属性上面的注解。实际开发中用到的并不多!故不推荐使用。
第四步,在创建对象所在的类上面使用注解实现
@Component(value="user") // 类似于<bean id="user" class="..." />
public class User {
public void add() {
System.out.println("add....................");
}
}
如若注解里面属性名称是value,则可以省略,所以上面的User类亦可这样写为:
@Component("user") // 类似于<bean id="user" class="..." />
public class User {
public void add() {
System.out.println("add....................");
}
}
第五步,编写测试类
在cn.itcast.anno包下编写一个TestDemo单元测试类。
public class TestDemo {
@Test
public void testUser() {
ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");
User user = (User) context.getBean("user");
System.out.println(user);
user.add();
}
}
Spring的bean管理中常用的注解
创建对象的注解有四个:
-
@Component:
作用在类上 -
@Repository
:用于对DAO实现类进行标注(持久层)。 -
@Service
:用于对Service实现类进行标注(业务层)。 -
@Controller
:用于对Controller实现类进行标注(WEB层)。
后三个注解是Spring中提供的@Component
的三个衍生注解(功能目前来讲是一样的),它们是为了让标注类本身的用途更清晰,Spring在后续的版本中会对其进行增强。
bean的作用范围的注解
@Scope
- singleton:单例,默认值
- prototype:多例
所以我们可通过注解设置创建对象是单例或者还是多实例的。这样User类的代码亦可写为:
@Service("user")
@Scope("singleton")
public class User {
public void add() {
System.out.println("add....................");
}
}
使用注解注入属性(对象)
这儿,我举个例子来说明如何使用注解注入(对象类型的)属性。
先创建业务层中的UserService类:
public class UserService {
public void add() {
System.out.println("service...........");
}
}
再创建持久层中的UserDao类:
public class UserDao {
public void add() {
System.out.println("dao................");
}
}
以上两个类都创建在cn.itcast.anno包中。我们要实现的目的是在UserService类里面调用UserDao类的方法,这样我们就要在UserService类里面得到UserDao类的对象。之前是采用xml配置文件的方式来注入属性的,本文将使用注解的方式完成注入属性的操作。
- 在UserService类里面定义UserDao类型属性
private UserDao userDao;
在UserService类里面定义UserDao类型的属性,由于是使用注解的方式,故不需要手动生成set方法。
- 进行注解方式实现属性注入
- 创建UserDao类的对象和UserService类的对象
@Service("userService")
public class UserService {
private UserDao userDao;
public void add() {
System.out.println("service...........");
userDao.add();
}
}
@Repository("userDao")
public class UserDao {
public void add() {
System.out.println("dao................");
}
}
- 在UserService类里面注入UserDao类的对象,使用注解来实现。首先我使用
@Autowired
注解来实现。
@Service("userService")
public class UserService {
@Autowired
private UserDao userDao;
public void add() {
System.out.println("service...........");
userDao.add();
}
}
注意:使用注解@Autowired
,它不是根据名字去找Dao,而是默认按类型进行装配。
当然了,也可使用@Resource
注解来实现,如下:
@Service("userService")
public class UserService {
@Resource(name="userDao")
private UserDao userDao;
public void add() {
System.out.println("service...........");
userDao.add();
}
}
注意,使用@Resource
注解,它默认是按名称进行注入的。在实际开发中,我们也是使用@Resource
注解来注入属性的,注解@Autowired
用到的并不多。