当前位置: 首页 > news >正文

10、底层注解-@Conditional条件装配

10、底层注解-@Conditional条件装配

`@Conditional`是Spring框架中用于条件装配的核心注解,它允许根据特定条件决定是否将某个组件或配置加载到Spring容器中。通过在类或方法上使用`@Conditional`,可以实现灵活的自动化配置,适应不同的环境和需求。

### 基本用法

`@Conditional`注解需要指定一个或多个实现了`Condition`接口的条件类。`Condition`接口的`matches`方法用于编写条件判断逻辑,返回`true`表示条件满足,组件将被加载;返回`false`则表示条件不满足,组件将被忽略。

```java

public class MyCondition implements Condition {

    @Override

    public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {

        // 编写条件判断逻辑,例如:

        return context.getEnvironment().getProperty("my.property") != null;

    }

}

@Configuration

public class AppConfig {

    @Bean

    @Conditional(MyCondition.class)

    public MyComponent myComponent() {

        return new MyComponent();

    }

}

```

在上述例子中,只有当`my.property`属性在配置文件中存在时,`MyComponent`才会被创建并注册到容器中。

### 常用内置条件注解

Spring Boot提供了一系列内置的条件注解,简化了常见的条件判断:

#### `@ConditionalOnProperty`

根据配置属性的值决定是否加载组件。

```java

@Bean

@ConditionalOnProperty(name = "my.feature.enabled", havingValue = "true")

public MyFeatureComponent myFeatureComponent() {

    return new MyFeatureComponent();

}

```

只有当`my.feature.enabled`属性值为`true`时,`MyFeatureComponent`才会被创建。

#### `@ConditionalOnClass`

当类路径中存在指定的类时,条件满足。

```java

@Bean

@ConditionalOnClass(name = "com.example.SomeClass")

public MyComponent myComponent() {

    return new MyComponent();

}

```

如果类路径中存在`com.example.SomeClass`,则`MyComponent`会被加载。

#### `@ConditionalOnMissingClass`

与`@ConditionalOnClass`相反,当类路径中**不存在**指定的类时,条件满足。

#### `@ConditionalOnBean`

当容器中已经存在指定类型的Bean时,条件满足。

```java

@Bean

@ConditionalOnBean(MyDependency.class)

public MyComponent myComponent() {

    return new MyComponent();

}

```

如果容器中已有`MyDependency`类型的Bean,`MyComponent`才会被创建。

#### `@ConditionalOnMissingBean`

与`@ConditionalOnBean`相反,当容器中**不存在**指定类型的Bean时,条件满足。

#### `@ConditionalOnExpression`

根据SpEL表达式的结果决定是否加载组件。

```java

@Bean

@ConditionalOnExpression("${my.expression} == true")

public MyComponent myComponent() {

    return new MyComponent();

}

```

当SpEL表达式`my.expression`的值为`true`时,`MyComponent`会被创建。

### 自定义条件注解

除了使用内置条件注解,还可以创建自定义条件注解,增强代码的可读性和复用性。

```java

@Target({ElementType.TYPE, ElementType.METHOD})

@Retention(RetentionPolicy.RUNTIME)

@Documented

@Conditional(MyCondition.class)

public @interface MyCustomCondition {

    // 可添加自定义属性

}

@Configuration

public class AppConfig {

    @Bean

    @MyCustomCondition

    public MyComponent myComponent() {

        return new MyComponent();

    }

}

```

### 注意事项

- **避免循环依赖**:在条件判断中应避免引用尚未初始化的组件,防止循环依赖。

- **性能考虑**:条件判断可能涉及较复杂的逻辑,应确保性能合理,避免影响应用启动速度。

- **缓存结果**:对于耗时的条件判断,可以利用`Condition`接口中的`getConfigurationPhase`方法,在配置阶段缓存结果,提升性能。

### 应用场景

- **多环境配置**:根据不同环境(开发、测试、生产)加载相应的组件。

- **特性开关**:根据配置决定是否启用某些功能模块。

- **依赖检测**:根据类路径中是否存在特定依赖,选择性地加载组件。

- **动态配置**:根据运行时条件动态调整组件的加载。

通过`@Conditional`注解,可以实现灵活的条件装配,提高Spring应用的配置灵活性和可维护性,适应各种复杂的业务场景。


文章转载自:

http://prBjs7id.fsnhz.cn
http://wfOsk7fQ.fsnhz.cn
http://HjXmL31w.fsnhz.cn
http://pthCrabr.fsnhz.cn
http://TNEYp7C3.fsnhz.cn
http://QAMtwuzr.fsnhz.cn
http://y8dOlEGr.fsnhz.cn
http://5KsLfQWi.fsnhz.cn
http://0j82OjuL.fsnhz.cn
http://y7eMKZsh.fsnhz.cn
http://HnZEq9OW.fsnhz.cn
http://TxLjHUkb.fsnhz.cn
http://U8AsK9wy.fsnhz.cn
http://sC4A5l7x.fsnhz.cn
http://JeqOOeoU.fsnhz.cn
http://F4mqlW2t.fsnhz.cn
http://e1dmBGHN.fsnhz.cn
http://nCKyR7Tx.fsnhz.cn
http://Q9dqcrI9.fsnhz.cn
http://8hitVRih.fsnhz.cn
http://CdRxfho6.fsnhz.cn
http://AKDR3xJ9.fsnhz.cn
http://9W83BJha.fsnhz.cn
http://QrEtCGDO.fsnhz.cn
http://GV3TUgR0.fsnhz.cn
http://E2f99Vn3.fsnhz.cn
http://X9D3ui5u.fsnhz.cn
http://jkegVP1u.fsnhz.cn
http://lV295zBf.fsnhz.cn
http://dPJNdfqI.fsnhz.cn
http://www.dtcms.com/a/201066.html

相关文章:

  • python可视化:公积金与商业贷款利率历年趋势1
  • 客户体验数据使用的三种视角——旅程视角
  • 升级mysql (rpm安装)
  • 【java第14集】java访问修饰符详解
  • HashMap 的特点及应用场景
  • 洛谷B3876—— [信息与未来 2015] 中间值
  • Java知识点-Stream流
  • UE5在Blueprint中判断不同平台
  • MySQL如何快速删除数据库中所有表数据
  • PyMOL结构对齐方式
  • 【深度学习新浪潮】什么是多模态大模型?
  • 列表 模版题单 12
  • Windows 如何安装CUDA
  • LeetCode 字符串类题目解析与 Java 实现指南(深度优化版)
  • leetcode 每日一题 1931. 用三种不同颜色为网格涂色
  • gtest 库的安装和使用
  • python打卡第30天
  • dbhub MCP服务搭建
  • cursor+MCP系列:12306-MCP车票查询工具
  • Logrotate:配置日志轮转、高效管理Linux日志文件
  • 秒删node_modules 极速删除 (rimraf工具)
  • 非金属材料的分类及应用
  • C++寻位映射的奇幻密码:哈希
  • NIFI 2.40简介及部署
  • unordered_map/set常用接口及模拟实现
  • 网络请求和状态管理
  • ebpf-verifier
  • Flink 非确定有限自动机NFA
  • JavaScript:PC端特效--缓动动画
  • SHELL练习题(1-11题)记录(牛客)