(1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值..)
(2)使用注解,注解作用在类上面,方法上面,属性上面
(3)使用注解目的:简化xml配置
(1)@Component (2)@Service (3)@Controller (4)@Repository
* 上面四个注解功能是一样的,都可以用来创建bean实例
<context:component-scan base-package="想要扫描包的位置,多个逗号分开">
</context:component-scan>
第三步 创建类,在类上面添加创建对象注解
在注解里面value属性值可以省略不写, 默认值是类名称,首字母小写 UserService -- userService
@Component(value = "userService")
//<bean id="userService" class=".."/>
public class UserService
{
public void add()
{ System.out.println("service add.......");
}
}
@Service
public class UserService {
//定义dao类型属性
//不需要添加set方法
//添加注入属性注解
@Autowired
private UserDao userDao;
public void add()
{ System.out.println("service add.......");
userDao.add();
} }
//定义dao类型属性
//不需要添加set方法
//添加注入属性注解
@Autowired
//根据类型进行注入
@Qualifier(value = "userDaoImpl1")
//根据名称进行注入
private UserDao userDao;
(3)@Resource:可以根据类型注入,可以根据名称注入
//@Resource //根据类型进行注入
@Resource(name = "userDaoImpl1")
//根据名称进行注入
private UserDao userDao;
(4)@Value:注入普通类型属性
@Value(value = "abc")
private String name;
(1)创建配置类,替代xml配置文件
@Configuration
//作为配置类,替代xml配置文件
@ComponentScan(basePackages = {"com.atguigu"})
public class SpringConfig { }
(2)编写测试类
@Test public void testService2()
{ //加载配置类
ApplicationContext context =
new AnnotationConfigApplicationContext(SpringConfig.class);
}