bean的管理-bean的获取

获取bean

  • 默认情况下,在Spring项目启动时 ,会把bean都创建好(但是还会受到作用域及延迟初始化的影响)放在IOC容器中,如果想主动获取这些bean,可以通过如下方式
    • 根据name获取bean
      *

      复制代码
        Object getBean(String name)
    • 根据类型获取bean
      *

      复制代码
        <T> T getBean(Class<T> requiredType)
    • 根据name以及类型获取bean
      *

      复制代码
        <T> T getBean(String name,Class<T> requiredType)

具体实现代码及运行结果如下

具体代码

java 复制代码
    @Autowired
    ApplicationContext applicationContext;  // 自动注入IOC容器对象

    @Test
    public void GetBean() {
        // 根据bean的名称获取
        DeptController bean1 = (DeptController) applicationContext.getBean("deptController");
        System.out.println(bean1);
        // 根据bean的类型获取
        DeptController bean2 = applicationContext.getBean(DeptController.class);
        System.out.println(bean2);
        // 根据bean的名称以及类型获取
        DeptController bean3 = applicationContext.getBean("deptController", DeptController.class);
        System.out.println(bean3);
    }

运行结果

在SpringBoot项目中设置bean对象

在Spring Boot中,可以使用注解来定义和配置Bean。常用的注解包括:

  • @Component:用于标识一个普通的Bean类。
  • @Service:用于标识一个服务类,通常用于业务逻辑的处理。
  • @Repository:用于标识一个数据访问类,通常用于数据库操作。
  • @Controller:用于标识一个控制器类,通常用于处理HTTP请求。

除了以上常用的注解外,还有一些特殊用途的注解,如:

  • @Configuration:用于标识一个配置类,通常用于配置Bean的创建和依赖关系。
  • @Autowired:用于自动注入依赖的Bean。
  • @Value:用于注入配置属性的值。

通过使用这些注解,可以将普通的Java类转化为Spring Bean,使其由Spring容器进行管理。Spring容器会负责创建、初始化和销毁这些Bean,并处理它们之间的依赖关系。在应用程序中,可以通过注入Bean来使用其提供的功能和服务。

bean作用域

第三方bean

相关推荐
今天和Aboo结婚了吗33 分钟前
【Broker一重启消息没了:一次RabbitMQ非持久化+没开Confirm的血亏事故】
java·rabbitmq·messagequeue·bug排查
无巧不成书021839 分钟前
Windows PowerShell执行策略详解:从npm报错到完美解决
前端·windows·npm·powershell执行策略·执行策略·npm.ps1·脚本报错
daidaidaiyu6 小时前
一文学习 工作流开发 BPMN、 Flowable
java
l1t7 小时前
DeepSeek总结的 pg_regresql插件:真正可移植的 PostgreSQL 统计信息
数据库·postgresql
oradh7 小时前
Oracle 11.2.0.1版本升级至11.2.0.4_单机环境
数据库·oracle·oracle11g·oracle升级
l1t7 小时前
用docker安装测试crate数据库
数据库·docker·容器·cratedb
anzhxu7 小时前
QT数据库(三):QSqlQuery使用
数据库·qt·oracle
身如柳絮随风扬7 小时前
MySQL核心知识
数据库·mysql
Z兽兽7 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
德彪稳坐倒骑驴7 小时前
Oracle 11g安装
数据库·oracle