IOC容器-Bean管理基于注解方式

IOC 操作 Bean 管理(基于注解方式)

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

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

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

3、基于注解方式实现对象创建

第一步 引入依赖

第二步 开启组件扫描

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

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

/**
 * @author RichieZhang
 * @create 2022-12-22 15:25
 */

// 在注解里面value属性值可以省略不写
// 默认值是类名称,首字母小写
///UserService -- userService
//@Component(value = "userService")   //<bean id="" class="" />

//@Service
//@Controller
//@Repository

@Service
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="top.qaqaq" 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="top.qaqaq">
        <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>

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

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

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

/**
 * @author RichieZhang
 * @create 2022-12-22 15:25
 */

// 在注解里面value属性值可以省略不写
// 默认值是类名称,首字母小写
///UserService -- userService
//@Component(value = "userService")   //<bean id="" class="" />

//@Service
//@Controller
//@Repository

@Service
public class UserService {

    //定义dao类型属性
    //不需要添加set方法
    //添加注入属性注解
    @Autowired  // 根据类型进行注入
    private UserDao userDao;

    public void add() {
        System.out.println("service add.......");
        userDao.add();
    }
}

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

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

/**
 * @author RichieZhang
 * @create 2022-12-22 15:25
 */

// 在注解里面value属性值可以省略不写
// 默认值是类名称,首字母小写
///UserService -- userService
//@Component(value = "userService")   //<bean id="" class="" />

//@Service
//@Controller
//@Repository

@Service
public class UserService {

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

    public void add() {
        System.out.println("service add.......");
        userDao.add();
    }
}
/**
 * @author RichieZhang
 * @create 2022-12-22 16:00
 */
public interface UserDao {
    public void add();
}
/**
 * @author RichieZhang
 * @create 2022-12-22 16:00
 */

@Repository(value = "userDaoImpl1")
public class UserDaoImpl implements UserDao{

    @Override
    public void add() {
        System.out.println("dao add........");
    }
}

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

/**
 * @author RichieZhang
 * @create 2022-12-22 15:25
 */

// 在注解里面value属性值可以省略不写
// 默认值是类名称,首字母小写
///UserService -- userService
//@Component(value = "userService")   //<bean id="" class="" />

//@Service
//@Controller
//@Repository

@Service
public class UserService {

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

//    @Resource   //根据类型进行注入
    @Resource(name = "userDaoImpl1") // 根据名称进行注入
    private UserDao userDao;

    public void add() {
        System.out.println("service add.......");
        userDao.add();
    }
}

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

/**
 * @author RichieZhang
 * @create 2022-12-22 15:25
 */

// 在注解里面value属性值可以省略不写
// 默认值是类名称,首字母小写
///UserService -- userService
//@Component(value = "userService")   //<bean id="" class="" />

//@Service
//@Controller
//@Repository

@Service
public class UserService {

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

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

//    @Resource   //根据类型进行注入
    @Resource(name = "userDaoImpl1") // 根据名称进行注入
    private UserDao userDao;


    public void add() {
        System.out.println("service add......." + name);
        userDao.add();
    }
}

6、完全注解开发

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

/**
 * @author RichieZhang
 * @create 2022-12-22 16:42
 */

@Configuration  // 作为配置类,代替xml配置文件
@ComponentScan(basePackages = {"top.qaqaq"})
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();
    }
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇