-------------------------------------------------android培训、java培训期待与您交流!----------------------------------
一、概述
注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记,没加,则等于没有某种标记,以后,javac编器,开发工具和其程序可以用反射来了解你的类及各种元素上有无何标记看你有什么标记,就去干相应的事。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。
1.@SuppressWarnings——@SupperssWarnings("deprecation")
@SuppressWarnings("unchecked")//不提示警告信息(@Retention("SOURCE")),不保存到Class文件中
2.@Deprecated——直接在刚才的类中增加一个方法,并加上@Deprecated标注,在另外一个类中调用这个方法,@Deprecated//不被推荐的代码,保存在Class文件(@Retention("RUNTIME")),也能被编译器调用
3.@Override——@Override//覆盖注解,只有编译时使用(@Retention("SOURCE")),不保存到Class文件中
4.@Retention——三种取值:RetetionPolicy.SOURCE、RetetionPolicy.CLASS、RetetionPolicy.RUNTIME;分别对应:java源文件-->class文件-->内存中的字节码
5.@Target
Target的默认值为任何元素,设置Target等于ElementType.METHOD,原来加在类上的注解就报错了,改为用数组方式设置{ElementType.METHOD,ElementType.TYPE}就可以了
二、自定义注解
@Retention(RetentionPolicy.RUNTIME) //随时可有用,用于反射
@Target(ElementType.METHOD)//应用在什么上面,用来修饰注释
@interface MyAnnotation//自定义注解
{
String value() default "lebyd";//使用默认赋值
Type type();//也可以是枚举类型
String[] name();//数组亦可
A1 ann() default @A1("Em");//注解类型
}
@Retention(RetentionPolicy.RUNTIME)
@interface A1
{
String value();
}
enum Type
{
Em,Dm,Cm,Am
}
class AnnotationTest
{
@Deprecated
@MyAnnotation(type=Type.Am,name={"Bm","Fm"},ann=@A1("Gm"))//调用方试,默认可不写,如name数组只有一个元素可省大括号
public void say()
{
System.out.println("hello");
}
}
三、反射使用注解
//反射获得方法
Class<AnnotationTest> ann=AnnotationTest.class;
Method method=ann.getMethod("say", new Class[]{});
//方法上的注解
if(method.isAnnotationPresent(MyAnnotation.class))
{
MyAnnotation a=method.getAnnotation(MyAnnotation.class);
System.out.println(a.value()+","+a.type()+","+a.name()[0]);
Annotation[] annotation=method.getAnnotations();
for(Annotation an:annotation)
{
//输出注解类型
System.out.println(an.annotationType());
}
//级联使用注解
System.out.println(a.ann().value());
}
-------------------------------------------------android培训、java培训期待与您交流!----------------------------------