定义注解

/**
 * 注解定义
 * 要定义两个元注解(元注解:注解的注解)
 * @Target 
 * 参数为ElementType数组类型,如果有多个参数,就要定义在大括号{}里面
 * 主要参数:
 * 	TYPE(Type 是 Java 编程语言中所有类型的公共高级接口。它们包括原始类型、参数化类型、数组类型、类型变量和基本类型。)		 
 * 		类、接口(包括注释类型)或枚举声明 
 *  FIELD 			  
 *  	字段声明(包括枚举常量)
 *  METHOD    		  
 *      方法声明
 * @Retention
 * 参数为RetentionPolicy类型
 * 三个参数:
 *  SOURCE 
 *     编译器javac要丢弃的注释(只是提示给开发者,有@Override,@SuppressWarnings)。
 *  CLASS 
 *     编译器将把注释记录在类文件(.class)中,但在运行时 VM 不需要保留注释。 
 *  RUNTIME
 *	      编译器将把注释记录在类文件中(.class),在运行时 VM 将保留注释,因此可以反射性地读取
 *		(@deprecated,下次调用这个注解标注的方法还会提示这个类已经过时)。
 * @author dhh
 *
 */
@Target({ElementType.TYPE,ElementType.METHOD})   //只能定义在type(类,接口...)上和方法上
@Retention(RetentionPolicy.RUNTIME)
public @interface MyInnocation {
	/**
	 * 定义一个String返回型的属性
	 * 用注解的时候就要@MyInnocation(str="xxx")
	 * 打印效果:
	 * MyInnocation innocation = AnnocationTest.class.getAnnotation(MyInnocation.class);
	 * System.out.println(innocation.color());
	 * @return
	 */
	String color() default "green";  
	
	/**
	 * 整型
	 * @return
	 */
	int num() default 2;
	/**
	 * 看到有时@MyInnocation("xxx") 
	 * 当只有value这一个属性的时候,或者说有多个属性,但是
	 * 这些属性都定义了default,可以省略"属性名="
	 * 如果看到@MyInnocation()也不要奇怪,那是因为value属性也定义了default值
	 * @return
	 */
	String value();
	
	/**
	 * 枚举类型,定义在EnumImpl中的枚举
	 * @return
	 */
	EnumImpl.Sex sex() default EnumImpl.Sex.FEMALE; //默认为女性
	
	/**
	 * 定义返回类型为注解的属性
	 * 引用@MyInnocation(inno=@Override(""))
	 */
	//Override inno() ;
	
	/**
	 * 引用的时候如果一个值,可以直接@MyInnocation(nums=3.3f)
	 * 多个值nums={...}
	 * @return
	 */
	float[] nums() default {3.5f,3,3f};
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用注解需要遵循以下步骤: 1. 创建自定义注解定义注解类并设置注解属性。 2. 在需要使用注解的地方使用注解:在类、方法、字段等上使用自定义注解。 3. 获取注解信息并进行处理:使用反射机制获取注解信息,根据注解信息进行相应的处理。 例如,在Java中使用注解可以增强代码的可读性、可维护性和可重用性。假设我们定义了一个自定义注解@MyAnnotation,我们可以在类、方法等上使用该注解。使用注解的方式如下所示: ``` @MyAnnotation(name = "test", value = "testValue") public class TestClass { @MyAnnotation(name = "testMethod", value = "testMethodValue") public void testMethod() { // ... } } ``` 在使用注解后,我们可以使用反射机制获取注解信息,比如获取@MyAnnotation中的name和value属性值: ``` Class<TestClass> clazz = TestClass.class; MyAnnotation classAnnotation = clazz.getAnnotation(MyAnnotation.class); System.out.println(classAnnotation.name()); // 输出 test System.out.println(classAnnotation.value()); // 输出 testValue Method method = clazz.getMethod("testMethod"); MyAnnotation methodAnnotation = method.getAnnotation(MyAnnotation.class); System.out.println(methodAnnotation.name()); // 输出 testMethod System.out.println(methodAnnotation.value()); // 输出 testMethodValue ``` 根据注解信息,我们可以进行相应的处理,比如根据@MyAnnotation注解中的name属性值来判断是否执行某些操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值