java基础---->java注解的使用(一)

本文介绍了Java SE 5中引入的注解特性,包括标准注解和元注解,并通过实例展示了自定义注解的创建及使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  注解是众多引入到Java SE5中的重要的语言变化之一。它为我们在代码中添加信息提供了一种形式化的方法,使我们可以在稍后某个时刻非常方便的使用这些数据。今天我们就开始学习一下java中注解的知识。

 

java注解的介绍

java内置了三种标准注解,以及四种元注解。元注解专职负责注解其他的注解。

标准注解:@Override,@Deprecated,@Suppresswarnings。

@Override:表示当前的方法定义将覆盖超类中的方法。如果你不小心拼写错误,或者方法签名对不上被覆盖的方法,编译器就会发出错误提示。

@Deprecated:如果程序使用了注解为它的元素,那么编译器会发出警告信息。

@Suppresswarnings:关闭不当的编译器警告信息。

元注解:@Target,@Retention,@Documented,@Inherited。

注解描述可选的参数
@Target表示该注解可以用于什么地方

CONSTRUCTOR、FIELD、LOCAL_VARLABLE、METHOD、PACKAGE、PARAMETER、TYPE

@Retention表示需要在什么级别保存该注解信息

SOURCE、CLASS、RUNTIME

@Documented将此注解包含在javadoc中 
@Inherited允许子类继承父类中的注解 

java注解的使用案例

测试的项目结构如下:

 

一、定义注解:

package com.linux.huhx.anno;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * @Author huhx
 * @Date: 2017/9/17 20:07
 *  定义注解:
 */

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface HuhxTest {
    public int id();

    public String description() default "no description";
}

 

二、编写要被注解的测试类

package com.linux.huhx.anno;

import java.util.List;

/**
 * @Author huhx
 * @Date: 2017/9/17 20:13
 */
public class PasswordUtils {

    @HuhxTest(id = 47, description = "password must contain at least one numeric")
    public boolean validatePassword(String password) {
        return password.matches("\\w*\\d\\w*");
    }

    @HuhxTest(id = 48)
    public String encryptPassword(String password) {
        return new StringBuilder(password).reverse().toString();
    }

    @HuhxTest(id = 49, description = "new passrod can't equal previously used ones")
    public boolean checkForNewPassword(List<String> prevPasswords, String password) {
        return !prevPasswords.contains(password);
    }
}

 

三、编写注解处理器

package com.linux.huhx.anno;

import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * @Author huhx
 * @Date: 2017/9/17 20:12
 */
public class UseCaseTracker {

    public static void trackUseCases(List<Integer> useCases, Class<?> cl) {
        for (Method m : cl.getDeclaredMethods()) {
            HuhxTest test = m.getAnnotation(HuhxTest.class);
            if (test != null) {
                System.out.println("found use case: " + test.id() + ", " + test.description());
                useCases.remove(new Integer(test.id()));
            }
        }
        for (int i : useCases) {
            System.out.println("warning: missing use case " + i);
        }
    }

    public static void main(String[] args) {
        List<Integer> useCases = new ArrayList<>();
        Collections.addAll(useCases, 47, 48, 49, 50);
        trackUseCases(useCases, PasswordUtils.class);
    }
}

运行的结果如下:

found use case: 49, new passrod can't equal previously used ones
found use case: 48, no description
found use case: 47, password must contain at least one numeric
warning: missing use case 50

 

友情链接

 

转载于:https://www.cnblogs.com/huhx/p/baseusejavaannotation1.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值