java注解(Annotation)编程

2024-08-25 18:04
文章标签 java 编程 注解 annotation

本文主要是介绍java注解(Annotation)编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 一、基本概念
    • 1. 定义
    • 2. 语法
    • 3. 类型
  • 二、内置注解
    • @Override:
    • @Deprecated:
    • @SuppressWarnings:
  • 三、元注解
    • @Target:
    • @Retention:
    • @Documented:
    • @Inherited:
  • 四、自定义注解
  • 五、注解的使用
  • 六、应用场景
  • 七、注解demo
    • 需求场景1 :假设需求是 字段脱敏 将数字2 都替换为 *

java注解(Annotation)是Java语言在JDK
5中引入的一个重要特性,它提供了一种为代码添加元数据的方式。这些元数据可以在编译时或运行时被读取,以执行特定的任务或提供额外的信息。以下是关于Java注解的详细解释:

一、基本概念

1. 定义

Java注解是代码中的特殊标记,用于给代码添加一些信息,这些信息不会改变代码的执行逻辑,但可以被编译器或其他工具用来生成代码、创建文档、做静态分析或进行其他处理。

2. 语法

Java注解以“@”符号开头,后跟注解名称和可能的参数。例如,@Override是一个Java内置注解,用于标记一个方法是重写父类的方法。

3. 类型

Java注解本质上是一种特殊的接口,但它的定义使用了@interface关键字而不是interface。注解内部可以定义元素(类似于接口中的方法),这些元素可以有默认值。

二、内置注解

Java提供了几种内置注解,它们分别用于不同的目的:

@Override:

表示当前的方法是重写父类中的方法。如果方法签名不匹配,编译器将报错。

@Deprecated:

表示某个类或方法已经过时,不推荐使用。使用这些元素时,编译器通常会给出警告。

@SuppressWarnings:

用于抑制编译器产生的特定警告。例如,@SuppressWarnings(“unchecked”)可以抑制未检查的转换警告。

三、元注解

元注解是用于定义注解的注解,Java提供了几种元注解来定义其他注解的行为:

@Target:

用于指定注解可以应用的Java元素类型(如类、方法、字段等)。

@Retention:

用于指定注解的保留策略,即注解信息在何时可用。它有三个值:SOURCE(只在源代码中保留)、CLASS(在源代码和类文件中保留,但运行时不可见)、RUNTIME(在源代码、类文件和运行时都保留,因此可以通过反射读取)。

@Documented:

表示该注解会被javadoc工具提取成文档。

@Inherited:

表示子类可以继承父类中的注解。

四、自定义注解

除了使用Java内置注解外,开发者还可以根据需要定义自己的注解。定义自定义注解时,需要使用@interface关键字,并指定注解的元素(如果有的话)。例如:

public @interface MyAnnotation {String value() default "defaultValue";int id() default -1;
}

五、注解的使用

注解可以在编译时或运行时被读取和处理。处理注解的常见方式有两种:

编译时处理:通过注解处理器(Annotation Processor)在编译时读取注解信息,并生成额外的代码或其他文件。这种方式常用于代码生成、静态分析等场景。

运行时处理:通过反射机制在运行时读取注解信息,并根据注解信息执行相应的逻辑。这种方式常用于框架设计、配置管理、动态代理等场景。

六、应用场景

Java注解在许多领域都有广泛的应用,包括但不限于:

框架设计:如Spring、Hibernate等框架大量使用注解来简化配置和代码编写。

代码生成:通过注解处理器自动生成重复或模板化的代码,如getter和setter方法、日志记录代码等。

配置管理:将配置信息直接写在代码中,减少外部配置文件的使用。

静态分析:通过注解提供额外的语义信息,帮助静态分析工具检测代码中的潜在问题。

动态代理:通过注解和反射机制实现动态代理模式,实现AOP等功能。

综上所述,Java注解是一种强大的元数据机制,它允许开发者给代码添加额外的信息,并在编译时或运行时读取和使用这些信息。通过合理使用注解,可以简化代码编写、提高开发效率、减少错误并提高代码质量。

七、注解demo

需求场景1 :假设需求是 字段脱敏 将数字2 都替换为 *

首先创建注解@interface

package com.demo.codedemolist.anotation;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface DesenStr {String source() default "";String target() default "";
}

创建注解操作的类

package com.demo.codedemolist.anotation;import com.demo.codedemolist.anotation.DesenStr;
import java.lang.reflect.Field;public class AnnotationClass {public Object parse(Object o) {Class<?> mClass = null;Object o1 = o;try {mClass = o.getClass();Field[] fields = mClass.getDeclaredFields();for (Field field : fields) {if (field.isAnnotationPresent(DesenStr.class)) {field.setAccessible(true);DesenStr annotation = field.getAnnotation(DesenStr.class);String source = annotation.source();// 待匹配String target = annotation.target();// 替换为String s = String.valueOf(field.get(o1));String replace = s.replace(source,target);field.set(o1, replace);}}} catch (IllegalAccessException e) {e.printStackTrace();}return o1;}
}

测试类

package com.demo.codedemolist;import com.demo.codedemolist.anotation.AnnotationClass;
import com.demo.codedemolist.anotation.UserInfo;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
class CodeDemoListApplicationTests {@Testvoid contextLoads() {}@Testvoid parse(){UserInfo userInfo= new UserInfo ("1328223342","张三");System.out.println(userInfo);// 1328223342 张三Object parseObject = new AnnotationClass().parse(userInfo);if(parseObject instanceof UserInfo){UserInfo newUserInfo = (UserInfo) parseObject;System.out.println(newUserInfo);// 132****342 张三}}}

测试结果输出

UserInfo(userId=1328223342, userName=张三)
UserInfo(userId=138**334, userName=张三)

这篇关于java注解(Annotation)编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106268

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor