注解的一些学习与理解

注解的一些学习与理解

注解

jdk5之后提供了一个特性,和类 接口同级
格式: @interface 注解名{}
作用:

  • 编译检查
  • 替代配置文件
  • 定义注解(元注解:注解上的注解)
  • 分析代码(用到反射)

java中3个注解

@Override:声明该方法是从分类上继承过来的,执行编译期的检查
@SuppressWarnings:抑制警告 值有很多,只需要知道一个 all  抑制所有的警告
@Deprecated:声明 该方法不赞成使用

自定义注解

注解属性:
注解本质就是一个接口,接口中可以有常量和抽象方法
抽象方法在注解中就称之为注解属性

注解属性类型:
基本类型:String、Class、Annotation、Enum:枚举以及以上类型对应的一维数组

注意:一旦注解有属性了,使用注解的时候必须赋值,(除非这个注解属性有默认值)
赋值的格式:@注解名(属性名=属性值)
若注解类型为数组,且只有一个值的时候,可以有两种写法

 1)方式1:属性名 = { 值 }
 2)方式2:属性名=属性值

属性名为value的时候,且只需要为这个value属性赋值的时候,value可以省略

元注解:

元注解:定义在注解上的注解

  1. @Retention 规定注解保留到什么阶段( 值为RetentionPolicy的三个枚举值)
    1)SOURCE:只在代码中保留,在字节码文件中就删除了(检查编译)
    2)CLASS:在代码和字节码文件中保留
    3)RUNTIME:所有阶段都保留(配置文件…)

    @Retention(RetentionPolicy.RUNTIME)
    public @interface MyTest {
    
    }
  2. @Target 规定注解作用在什么上面(值为ElementType的枚举值)
    1)TYPE:作用在类 接口 等上面
    2)METHOD:作用方法上面
    3)FIELD:作用字段上面
    例:下面的注解就只能用在方法上

    @Target(ElementType.METHOD)
    public @interface MyAnnotation4 {
    }

Spring框架中Bean管理的常用注解

  1. @Component:组件.(作用在类上)

  2. Spring中提供@Component的三个衍生注解:(功能目前来讲是一致的)
    1) @Controller – 作用在WEB层
    2) @Service – 作用在业务层
    3) @Repository – 作用在持久层

    说明:这三个注解是为了让标注类本身的用途清晰,Spring在后续版本会对其增强

  3. 属性注入的注解(说明:使用注解注入的方式,可以不用提供set方法)
    1) 如果是注入的普通类型,可以使用value注解

    @Value          -- 用于注入普通类型
    

    2) 如果注入的是对象类型,使用如下注解

        @Autowired      -- 默认按类型进行自动装配
             如果想按名称注入
        @Qualifier  -- 强制使用名称注入
    

    3)@Resource – 相当于@Autowired和@Qualifier一起使用

        强调:Java提供的注解
        属性使用name属性
    

技术分析之通知类型

  1. 通知类型
    1) @Before – 前置通知
    2) @AfterReturing – 后置通知
    3) @Around – 环绕通知(目标对象方法默认不执行的,需要手动执行)
    4) @After – 最终通知
    5) @AfterThrowing – 异常抛出通知

  2. 配置通用的切入点
    使用@Pointcut定义通用的切入点

    @Aspect
        public class MyAspectAnno {
            @Before(value="MyAspectAnno.fn()")
            public void log(){
                System.out.println("记录日志...");
            }
            @Pointcut(value="execution(public void com.itheima.demo1.CustomerDaoImpl.save())")
            public void fn(){}
        }
带开环升压转换器和逆变器的太阳能光伏系统 太阳能光伏系统驱动开环升压转换器和SPWM逆变器提供波形稳定、设计简单的交流电的模型 Simulink模型展示了一个完整的基于太阳能光伏的直流到交流电力转换系统,该系统由简单、透明、易于理解的模块构建而成。该系统从配置为提供真实直流输出电压的光伏阵列开始,然后由开环DC-DC升压转换器进行处理。升压转换器将光伏电压提高到适合为单相全桥逆变器供电的稳定直流链路电平。 逆变器使用正弦PWM(SPWM)开关来产生干净的交流输出波形,使该模型成为研究直流-交流转换基本操作的理想选择。该设计避免了闭环和MPPT的复杂性,使用户能够专注于光伏接口、升压转换和逆变器开关的核心概念。 此模型包含的主要功能: •太阳能光伏阵列在标准条件下产生~200V电压 •具有固定占空比操作的开环升压转换器 •直流链路电容器,用于平滑和稳定转换器输出 •单相全桥SPWM逆变器 •交流负载,用于观察实际输出行为 •显示光伏电压、升压输出、直流链路电压、逆变器交流波形和负载电流的组织良好的范围 •完全可编辑的结构,适合分析、实验和扩展 该模型旨在为太阳能直流-交流转换提供一个干净高效的仿真框架。布局简单明了,允许用户快速了解信号流,检查各个阶段,并根据需要修改参数。 系统架构有意保持模块化,因此可以轻松扩展,例如通过添加MPPT、动态负载行为、闭环升压控制或并网逆变器概念。该模型为进一步开发或整合到更大的可再生能源模拟中奠定了坚实的基础。
@SysLog 注解是一个自定义注解,可用于代码增强,在程序运行过程中加入特定逻辑,例如在所有 Java 的控制器方法中加入日志。以下从定义、使用等方面介绍相关知识: ### 定义注解 通过 Java 代码定义 @SysLog 注解,示例如下: ```java @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface SysLog { String value() default ""; } ``` 这里使用了元注解: - `@Target(ElementType.METHOD)`:表示该注解只能用于方法上。 - `@Retention(RetentionPolicy.RUNTIME)`:意味着注解在运行时保留,这样程序在运行期间可以通过反射机制获取注解信息。 - `@Documented`:表示该注解会被包含在 JavaDoc 中。 注解中定义了一个属性 `value`,默认值为空字符串,可用于传递一些自定义信息,如操作描述 [^3]。 ### 使用注解 在需要应用特定逻辑的方法上标注 @SysLog 注解,示例代码如下: ```java @SysLog("保存用户") @PostMapping("/save") public Result save(@RequestBody SysUserEntity user) { sysUserService.save(user); return Result.ok(); } ``` 此例中,`@SysLog("保存用户")` 为注解添加了具体的操作描述,当该方法被调用时,可利用拦截器等机制获取该注解及描述信息,进而执行相应的增强逻辑,如记录日志等 [^1]。 ### 结合拦截器使用 使用拦截器结合 @SysLog 注解时,可在拦截器中获取方法上的 @SysLog 注解信息,执行自定义逻辑,比如记录日志。配置完成后,只需在需要的方法上标注 @SysLog 注解即可使用: ```java @SysLog @PostMapping("/add") public String add() { return ""; } ``` 在拦截器里,可通过反射获取方法上的 @SysLog 注解,根据注解信息执行相应操作 [^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值