java中的常用注解

Java注解的使用与元注解介绍

注解

  注解(Annotation)也被称为元数据(Metadata),用于修饰解释 包、类、方法、属性、构造器、局部变量等数据信息。 和注释一样,注解不影响程序逻辑,但注解可以被编译或运行,相当于嵌入在代码中的补充信息。

  在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE中注解占据了更重要的角 色,例如用来配置应用程序的任何切面,代替javaEE旧版中所遗留的繁冗代码和XML配置等。


1 基本介绍

  使用 Annotation 时要在其前面增加 @ 符号, 并把该 Annotation 当成一个修饰符使用。用于修饰它支持的程序元素。

  3个基本的 Annotation:

  1. @Override: 限定某个方法,是重写父类方法,该注解只能用于方法。
  2. @Deprecated: 用于表示某个程序元素(类、方法等)已过时,通常是因为所修饰的结构危险或存在更好的选择。
  3. @SuppressWarnings: 抑制编译器警告。

2 Annotation 应用

  下面进行案例演示。

(1) @Override 注解的使用

  限定某个方法,是重写父类的方法,该注解只能用于方法。

源码展示:(具体的解释将在后面展开), @interface 表示一个注解类,@Target, @Retention 是修饰注解的注解,称为元注解。

在这里插入图片描述

public class Test {
    public static void main(String[] args) {
        
    }
}
class Father {
    public void say() {
        System.out.println("我是Father类的say()方法");
    }
}
class Son extends Father {
    @Override
    public void say() {
        System.out.println("我是Son类重写的say()方法");
    }
    //老韩解读
    //1. @Override 注解放在 say() 方法上,表示子类的say方法重写了父类的say
    //2. 这里如果没有写 @Override 还是重写了父类say
    //3. 如果你写了@Override 注解,编译器就会去检查该方法是否真的重写了父类的
    //方法,如果的确重写了,则编译通过,如果没有构成重写,则编译错误
    /*
    @Override
    public void f() {}
    解释:使用了 Override 注解,编译器会检查该方法是否构成了重写,
    	如果父类没有此方法,编译也无法通过
    */  
}

总结:

  1. @Override 表示指定重写父类的方法(从编译层面验证),如果父类没有 say() 方法,则会报错。
  2. 如果不写 @Override 注解,而父类仍有 public void say() {} ,仍然构成重写。
  3. @Override 只能修饰方法,不能修饰其他类、包、属性等。

(2) @Deprecated 注解的使用

  用于表示某个程序元素(类、方法等)已过时。

源码展示:

在这里插入图片描述

//修饰类表示类已过时
@Deprecated
class A {
    //修饰属性,表示属性已过时
    @Deprecated
    private int n;
    
    //修饰方法,表示方法已过时
    @Deprecated
    public void say(){}
    
    //1.@Deprecated修饰某个元素,表示该元素已经过时
	//2.即不在推荐使用,但是仍然可以使用
    //3.可以修饰方法,类,字段, 包, 参数 等等
	//4.@Deprecated 可以做版本升级过渡使用
}

  使用 @Deprecated 修饰的元素在 IDEA 中会有如下效果:

在这里插入图片描述

总结:

  1. 用于表示某个程序元素(类、方法等)已过时。
  2. 可以修饰方法、类、字段、包、参数等。
  3. @Deprecated 可以做版本升级过渡使用。

(3) @SuppressWarnings 注解的使用

  抑制编译器的警告。

源码为:

在这里插入图片描述

常见的指定的警告类型:

//1. 当我们不希望看到这些警告的时候,可以使用 SuppressWarnings注解来抑制警告信息
//2. 在{""} 中,可以写入你希望抑制(不显示)警告信息
//3. 可以指定的警告类型有

//all,抑制所有警告
//boxing,抑制与封装/拆装作业相关的警告
//cast,抑制与强制转型作业相关的警告
//dep-ann,抑制与淘汰注释相关的警告
//deprecation,抑制与淘汰的相关警告
//fallthrough,抑制与 switch 陈述式中遗漏 break 相关的警告
//finally,抑制与未传回finally 区块相关的警告
//hiding,抑制与隐藏变数的区域变数相关的警告
//incomplete-switch,抑制与 switch 陈述式(enum case)中遗漏项目相关的警告
//javadoc,抑制与 javadoc 相关的警告
//nls,抑制与非nls 字串文字相关的警告
//null,抑制与空值分析相关的警告
//rawtypes,抑制与使用raw类型相关的警告
//resource,抑制与使用 Closeable 类型的资源相关的警告
//restriction,抑制与使用不建议或禁止参照相关的警告
//serial,抑制与可序列化的类别遗漏serialVersionUID 栏位相关的警告
//static-access,抑制与静态存取不正确相关的警告
//static-method,抑制与可能宣告为 static 的方法相关的警告
//super,抑制与置换方法相关但不含super呼叫的警告
//synthetic-access,抑制与内部类别的存取未最佳化相关的警告
//sync-override,抑制因为置换同步方法而遗漏同步化的警告
//unchecked,抑制与未检查的作业相关的警告
//unqualified-field-access,抑制与栏位存取不合格相关的警告
//unused,抑制与未用的程式码及停用的程式码相关的警告

  关于SuppressWarnings 作用范围是和你放置的位置相关,比如 @SuppressWarnings 放置在 main方法,那么抑制警告的范围就是 main 通常我们可以放置具体的语句, 方法, 类。

  该注解类有数组 String[] values() 设置一个数组比如 {“rawtypes”, “unchecked”, “unused”}.

//作用于类
@SuppressWarnings({"all"})
class Test {
}

//也可以指定多个警告类型
class Test2 {
    @SuppressWarnings({"unused","unchecked"})
    private int n;
    public void say{}
}

3 元注解

  JDK 的元注解用于修饰其他的注解。

3.1 元注解的种类

  1. Retention :指定注解的作用范围,三种 SOURCE, CLASS, RUNTIME 。
  2. Target :指定注解可以在哪些地方使用。
  3. Documented :指定该注解是否会在javadoc体现。
  4. Inherited :子类会继承父类注解。
(1) @Retention 元注解

  只能用于修饰一个 Annotation 定义, 用于指定该 Annotation 可以保留多长时间,@Retention 包含一个 RetentionPolicy 类型的成员变量, 使用 @Rentention 时必须为该 value 成员变量指定值:

@Retention 的三种值:

  1. RetentionPolicy.SOURCE: 编译器使用后,直接丢弃这种策略的注释。
  2. RetentionPolicy.CLASS: 编译器将把注解记录在 class 文件中. 当运行 Java 程序时, JVM 不会保留注解。这是默认值
  3. RetentionPolicy.RUNTIME:编译器将把注解记录在 class 文件中。 当运行 Java 程序时, JVM 会保留注解.,程序可以通过反射获取该注解。
(2) @Target 元注解

  用于修饰 Annotation 定义,用于指定被修饰的 Annotation 能用于修饰哪些程序元素。@Target 也包含一个名为 value 的成员变量。

@Deprecated 源码:

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, MODULE, PARAMETER, TYPE})
public @interface Deprecated {
    /**
     * Returns the version in which the annotated element became deprecated.
     * The version string is in the same format and namespace as the value of
     * the {@code @since} javadoc tag. The default value is the empty
     * string.
     *
     * @return the version string
     * @since 9
     */
    String since() default "";

    /**
     * Indicates whether the annotated element is subject to removal in a
     * future version. The default value is {@code false}.
     *
     * @return whether the element is subject to removal
     * @since 9
     */
    boolean forRemoval() default false;
}

(3) @Documented 元注解

  用于指定被该元注解 修饰的 Annotation 类将被 javadoc 工具提取成文档时,可以看到该注解。(定义为 Documented 的注解必须设置 Retention 值为 RUNTIME)

源码为:

在这里插入图片描述

(4) @Inherited 注解

  被它修饰的 Annotation 将具有继承性,如果某个类使用了被 @Inherited 修饰的 Annotation,则其子类将自动具有该注解。(使用较少,了解即可)

<think>好的,我现在需要回答用户关于Java常用注解及其作用的问题。首先,我要回忆一下常见的Java注解,特别是Spring框架中的,因为用户提供的引用中提到了很多Spring相关的注解。用户可能希望了解这些注解的基本功能、使用场景以及示例代码。 首先,我需要整理引用中的信息。引用[1]提到了一些Spring常用注解,比如@Component、@Autowired、@Controller、@Service、@Repository、@RequestMapping、@GetMapping、@PostMapping。引用[3]详细说明了@Component和@Autowired的作用,并给出了示例代码。引用[2]展示了@ModelAttribute的使用方法。引用[4]虽然主要关于正则表达式,但可能暂时用不上。 接下来,我应该分类这些注解,比如分为Spring核心注解、依赖注入注解、Web MVC注解、配置相关注解等。这样结构会更清晰。每个注解需要简要说明作用,并给出示例代码。例如,@Component用于标记类为Spring组件,@Autowired用于自动装配依赖。 还要注意用户提到的示例代码是否正确,是否符合LaTeX格式要求。比如行内数学表达式需要用$...$,但这里可能不需要数学公式,主要关注代码块和注解的解释。同时,独立公式可能需要用$$...$$,但问题中可能不涉及数学公式,所以可能可以忽略这部分。 需要确保回答使用中文,结构清晰,分点说明。每个注解的作用、解释、示例分开,方便用户理解。此外,根据用户的要求,生成相关问题,可能涉及注解的使用场景、区别、组合使用等。 检查是否有遗漏的重要注解,比如@Configuration、@Bean、@Scope、@Value等,这些也是Spring中常用的。同时,是否要包括JPA相关的注解,如@Entity、@Table,或者Spring Boot的@SpringBootApplication?但用户提供的引用中没有提到这些,可能应优先考虑引用中提到的内容,再补充一些常见的。 另外,注意引用标识的位置,例如在提到异常处理时引用[1],提到@ModelAttribute时引用[2],@Autowired时引用[3]。确保每个引用正确对应到用户提供的来源。 最后,生成的相关问题需要与注解相关,可能包括如何选择不同的注解注解的工作原理、常见错误用法等。确保问题有针对性,帮助用户进一步学习。 现在开始组织内容,先分大类,再逐个注解说明,并附上示例代码。检查是否符合格式要求,比如代码块用三个反引号包裹,注解名称用代码样式。确保没有使用Markdown格式,但用户的示例中允许代码块,所以没问题。 可能还需要补充一些注解,比如@PathVariable、@RequestParam、@ResponseBody等,这些在Web开发中也很常用。但根据引用内容,主要覆盖用户提供的注解,再适当补充其他常用注解。 总之,步骤是:分类整理注解,详细说明每个的作用和示例,正确引用来源,最后生成相关问题。</think>### Java常用注解及其作用详解 #### 一、Spring核心组件注解 1. **`@Component`** - **作用**:标记类为Spring管理的组件,会被自动扫描并注册为Bean。 - **示例**: ```java @Component public class MyComponent { // 类的实现 } ``` [^3] 2. **`@Controller`/`@Service`/`@Repository`** - **作用**: - `@Controller`:标记为Web控制器,处理HTTP请求。 - `@Service`:标记为业务逻辑层组件。 - `@Repository`:标记为数据访问层组件,用于数据库操作。 - **示例**: ```java @Controller public class UserController { // 处理用户相关请求 } ``` [^1] --- #### 二、依赖注入注解 1. **`@Autowired`** - **作用**:自动装配依赖,根据类型匹配Bean并注入到字段、构造函数或方法参数中。 - **示例**: ```java @Service public class UserService { @Autowired private UserRepository userRepository; } ``` 2. **`@Qualifier`** - **作用**:与`@Autowired`配合使用,指定具体Bean的名称以解决歧义。 - **示例**: ```java @Autowired @Qualifier("mysqlUserRepository") private UserRepository userRepository; ``` --- #### 三、Web请求处理注解 1. **`@RequestMapping`** - **作用**:映射HTTP请求路径到控制器方法,支持多种请求方法。 - **示例**: ```java @Controller @RequestMapping("/user") public class UserController { @RequestMapping(value = "/list", method = RequestMethod.GET) public String listUsers() { return "user/list"; } } ``` [^1] 2. **`@GetMapping`/`@PostMapping`** - **作用**:简化`@RequestMapping`,分别处理GET和POST请求。 - **示例**: ```java @GetMapping("/profile") public String getUserProfile() { return "profile"; } ``` 3. **`@ModelAttribute`** - **作用**:将请求参数绑定到模型对象,或从模型中提取数据。 - **示例**: ```java public void sayHello(@ModelAttribute("user") User user) { // 使用user对象 } ``` [^2] --- #### 四、配置与元数据注解 1. **`@Configuration`** - **作用**:标记类为配置类,定义Bean的创建逻辑。 - **示例**: ```java @Configuration public class AppConfig { @Bean public DataSource dataSource() { return new HikariDataSource(); } } ``` 2. **`@Value`** - **作用**:注入配置文件中的属性值。 - **示例**: ```java @Value("${database.url}") private String dbUrl; ``` --- #### 五、其他常用注解 1. **`@ExceptionHandler`** - **作用**:定义全局异常处理方法。 - **示例**: ```java @ExceptionHandler(RuntimeException.class) public ResponseEntity<String> handleRuntimeException(RuntimeException ex) { return ResponseEntity.status(500).body(ex.getMessage()); } ``` [^1] 2. **`@Param`** - **作用**:在MyBatis中绑定方法参数到SQL语句的变量名。 - **示例**: ```java @Select("SELECT * FROM user WHERE name = #{name}") User findByName(@Param("name") String userName); ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值