-----------android培训、java培训、java学习型技术博客、期待与您交流!------------
1.注解是jdk1.5出现的新特性
在jdk1.5中一种提供了3种注解:Deprecated:用 @Deprecated 注释的程序元素,不鼓励程序员使用这样的元素,通常是因为它很危险或存在更好的选择。在使用不被赞成的程序元素或在不被赞成的代码中执行重写时,编译器会发出警告。(即提示程序员该方法已过时)
Override:表示一个方法声明打算重写超类中的另一个方法声明。如果方法利用此注释类型进行注解但没有重写超类方法,则编译器会生成一条错误消息。 (提示覆盖,如果没有覆盖父类中的方法将提示错误信息)
SuppressWarning:指示应该在注释元素(以及包含在该注释元素中的所有程序元素)中取消显示指定的编译器警告。(取消警告)
演示:
public class Annotation {
@SuppressWarnings("deprecation")//创建了一个注解的类的实例对象(提醒用户所用的方法已过时)
public static void main(String[] args) {
// TODO 自动生成的方法存根
System.runFinalizersOnExit(true);
}
@Deprecated//提示用户改方法已过时
public static void<del> sayHello</del>(){
System.out.println("你好");
}
}
public static void main(String[] args) {
// TODO 自动生成的方法存根
Annotation.<del>sayHello</del>();//提示已过时
}
总结:注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记,没加,则等于没有某种标记,以后,javac编译器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无何种标记,看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。
自定义注解:
1.注解的范围定义:
@Retention(RetentionPolicy.RUNTIME)//这句表示的意思是将注解保留到运行时期
@Target({ElementType.ANNOTATION_TYPE,ElementType.METHOD,ElementType.PACKAGE})//指定注解可以运用在那些地方
//RetentionPolicy是一个枚举类型,其中有三个元素RUNTIME、SOURCE、CLASS
//CLASS
//编译器将把注释记录在类文件中,但在运行时 VM 不需要保留注释。
//RUNTIME
//编译器将把注释记录在类文件中,在运行时 VM 将保留注释,因此可以反射性地读取。
//SOURCE
//编译器要丢弃的注释。
创建注释对象(注释是一种接口):
<span style="font-size:18px;">MyAnnotation myAnnotation = AnnotationTest.class.getAnnotation(MyAnnotation.class);//创建注释对象</span>
代码笔记:
package haHa.lib;
import java.lang.reflect.*;
/*
* 一个注解就是一个类
* */
@itCastAnnotation
@MyAnntation(color = "red", args = {2,5,6})
public class Annotation {
//@SuppressWarnings("deprecation")//创建了一个注解的类的实例对象(提醒用户所用的方法已过时)
public static void main(String[] args) throws Exception, Exception {
// TODO 自动生成的方法存根
//System.runFinalizersOnExit(true);
System.out.println(Annotation.class
.isAnnotationPresent(itCastAnnotation.class));//判断某个类上是否有某种注解
Class myanntation=MyAnntation.class;//表示注释的字节码(这是我为后面测试方法和属性用的,测一下怎样获得注释的属性)
MyAnntation ma=Annotation.class.getAnnotation(MyAnntation.class);//用反射创建注释的对象的方法
//System.out.println( ma.args().length);
Field[] f=myanntation.getFields();
System.out.println(f.length);
Method[] m=myanntation.getDeclaredMethods();
System.out.println(m.length);
for(Field f1:f){
//System.out.println("ooo");
System.out.println(f1.toGenericString()+f1.get(f1).toString());//说明Annation类可以定义字段(属性)
//System.out.println(f1.toString());
}
}
@Deprecated//提示用户改方法已过时
public static void sayHello(){
System.out.println("你好");
}
}
package haHa.lib;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target(value=ElementType.TYPE)
public @interface MyAnntation {
String color();//定义方法。
int age=20;//定义属性(字段)但是该字段没有默认初始化值(如果将Anntation看做是一个类的话)
String name() default "sheng";//为该方法(张孝祥老师说是属性)赋默认值;
int[] args();
}
//Annotation类中的属性有些类似于普通类中的方法,可以用反射向获取普通类的方法那样获取注释的属性