<---------------------- ASP.Net+Android+IOS开发、.Net培训、期待与您交流! ----------------------/p>
java 1.5的新特性,注解。注解类:Annotation
顾名思义:注解是对Java中程序进行说明。
小知识:main方法可以不属于当前那个类。
注意:一个注解就是一个类,我在这里用这个注解就相当于创建了这个类的实例对象。
*集合在进行对象比较是否相等的的时候,equals方法是object的,而自己写一个传入非object的参数,相当于是overload,重载,等于白写了。
如果找出这样的问题,可以添加注解 @override 可以检查是否正确覆盖。
*要养成一个良好的编码习惯,
例如AnnotationTest,注意动词和名词的顺序。在类中或者方法中有不同的表现。
@SuppressWarnings("deprecation") //抑制警告信息,也叫忽略警告:反对。因为deprecated,过时。System.runFinalizersOnExit(true);
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
package Java5新特性注解;
import 反射学习之javaBean的内省简单操作.ReflectPoint;
public class TsetAnnotation {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
//引用一个被注解的方法 ,出现了注解的效果。
AnnotationTest.sayHello();
}
}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
注解: 1是标记方法过时。如果有这么一个方法,很多人使用,而一部分人不再去用它,为了照顾新老用户。可以注解
2是压制警告 。
3说明子类是否覆盖父类的方法。还有没有提供其他的结果呢。在Java.lang包下
注解的作用:
1生成文档。这是最常见的,也是java 最早提供的注解。常用的有@see @param @return 等
2跟踪代码依赖性,实现替代配置文件功能。比较常见的是spring 2.5 开始的基于注解配置。 代替配置文件非常强大。
作用就是减少配置。现在的框架基本都使用了这种配置来减少配置文件的数量。也是
3在编译时进行格式检查。如@override 放在方法前,如果你这个方法并不是覆盖了超类方法,则编译时就能检查出。
比如对过时的方法进行提示。
但是不表示过时的不不能用,会向下兼容。
比如对一个方法进行注解
@Deprecated 表示下面这个方法过时了
平时我们生成重写的时候,程序也会跳出注解。
这些注解有其独特的作用,这样就能对我们重写进行检查。
注解究竟什么,
注解相当于是一个标记。加了注解就等于打上了某种标记,没加,则等于没有加标记。
以后Java编辑器,开发工具和其他程序可以用反射来了解你的类及各种元素上有无各种标记,看你有什么标记,就去干相应的事,标记可以添加在包,类,字段,方法,方法的参数以及局部变量上。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
package Java5新特性注解;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import 枚举学习.EnumTest;
//这就是一个注解。
@Retention(RetentionPolicy.RUNTIME) //这个注解括号内的内容我们也可以看成一个value,这个值的返回值类型是retentionPolicy类型的枚举对象。
@Target({ElementType.METHOD,ElementType.TYPE}) //这里可以限定注解使用的位置。
public @interface ItcastAnnotation {
String color() default "blue"; //如何理解:表示这是一个在注解里color抽象方法,返回值是String。 public可以加可以不加。
String value(); //也可以给color设置default值
int[] arrayattr() default{2,3,4};
EnumTest.Trafficlamp lamp() default EnumTest.Trafficlamp.RED;//这里是用注解实现枚举属性
MetaAnnotation annotationattr() default @MetaAnnotation("dd");//用注解得到注解
}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
注解就相当于一个你源程序中要调用的类,要在源程序中应用某个注解,得闲准备好这个注解类。就像你要调用某个类,得先有开发好的这个类。
注解类如何写呢?
类似于接口的写法,不同的是关键字前面加上了@ 例如:
@interface A
{}
在应用中的体现:
@A
class B
{}
而当有另外一个类调用上面这个类的时候呢,会检查上面这个类是否有注解。
C是对应用了注解类的类,进行反射操作的类。
class C{
B.class.isAnnotionPresent(A.class);
A a=B.class.getAnnotion(A.class);
}
元注解
元数据
元信息: 信息的信息,对信息进行解释的信息,比如汽车是一个信息,而哪些发动机,引擎就是信息的信息。
注意:class里面的文件不是字节码,只有类加载器将其进行加载至内存,加载完以后会对class文件进行一个处理,例如安全检查等。处理完
最终得到的二进制数据才是字节码文件。
类加载器在把class文件加载到内存的时候也有转换,转换的时候把class里面的注解是否保留下来,这也有说法。
所以说一个注解的生命周期有三个阶段( RententionPolicy 保留策略)
默认是class阶段。
1源文件是一个阶段RententionPolicy.SOURCE
2class文件是一个阶段RententionPolicy.CLASS
3内存中的字节码文件内容是一个阶段RententionPolicy.RUNTIME
这三个阶段取值就是枚举。
思考:@override 重写,检查 @SupperssWarnings(禁止发表警告)和@Deprecated的这三个注解的属性值分别是什么。
1在检查重载的时候是对源文件进行检查,属于编译阶段,所以是source阶段,
2suppersswarnings也是编译期间的检查,处理编译问题,所以也是source阶段.
3而deprecated 说明过时,不是编译期,而是runtime,是扫描的是二进制文件。是调入内存后再进行扫描,比如那个方法过时了。
所以说它的声明周期是运行保留
注意:Javac将源文件翻译成字节码文件的时候有可能去掉这个注解。 类加载器把class文件加载至内存的时候也有可能去掉注解。
如何保留注解?
可以在设计注解的时候加上一个@retention进行生命周期的说明,
说明注解是在源文件阶段RetentionPolicy.SOURCE
或是在class文件阶段,RetentionPolicy.CLASS,还算在字节码运行阶段RetentionPolicy.RUNTIME.
请记住:注解default在retentionpolicy.CLASS阶段。
@Target({ElementType.METHOD,ElementType.TYPE}) //这里可以限定注解使用的位置,比如在那些成分上面,类名还是方法。
可以引入多个引用。
在1.5里面引入了很多新特性,其中type描述类比class更准确,TYPE是class的父类。class值是类里面的一种。
注解的功能为什么这么这么强大:因为它有属性。
属性有什么作用呢?
一定程度上可以起到替代文件配置的功能。
比如一个公司员工的工牌就是注解,而这么区分员工呢,上面的信息就是属性。
注解是有返回值的,而返回类型只能是原始类型,八个
字符串类型
class类型
枚举类型
注解类型,
还可以是以上类型的数组。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
package Java5新特性注解;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import 枚举学习.EnumTest;
//这就是一个注解。
@Retention(RetentionPolicy.RUNTIME) //这个注解括号内的内容我们也可以看成一个value,这个值的返回值类型是retentionPolicy类型的枚举对象。
@Target({ElementType.METHOD,ElementType.TYPE}) //这里可以限定注解使用的位置,大括号内表示是一个数组。
public @interface ItcastAnnotation {
String color() default "blue"; //如何理解:表示这是一个在注解里color抽象方法,返回值是String。 public可以加可以不加。
String value(); //也可以给color设置default值
int[] arrayattr() default{2,3,4};
EnumTest.Trafficlamp lamp() default EnumTest.Trafficlamp.RED;//这里是用注解实现枚举属性
MetaAnnotation annotationattr() default @MetaAnnotation("dd");//用注解得到注解
//在是注解的属性值还是一个注解,算是嵌套。
}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
package Java5新特性注解;
@ItcastAnnotation(annotationattr=@MetaAnnotation("zxx"),color="red",value="abc",arrayattr=100)
//这里添加了一个自己写的注解,写程序需求是检查这个类上是否有这个注解。并具备属性
//如果数组里面只有一个元素,那么可以身略大括号。
public class AnnotationTest {
@SuppressWarnings("deprecation")
//抑制警告信息:反对。因为deprecated,过时。括号里面的内容也可以看成一个特殊的值。
@ItcastAnnotation("xyz") //value属性的特殊应用,省却了等号。
public static void main(String[] args) {
System.runFinalizersOnExit(true); //下面这句话被工具友好提示,在Javac命令行中会被提示deprecated的注意。
//有的时候,虽然main方法放在了一个类里面,但是并不代表这个代码就属于这个类。
//得到注解的验证,先得到本类的字节码文件,然后将指定的注解文件传入到得到注解的参数。
if (AnnotationTest.class.isAnnotationPresent(ItcastAnnotation.class)) {
ItcastAnnotation annotation=(ItcastAnnotation)AnnotationTest.class.getAnnotation(ItcastAnnotation.class);
//用注解的类对象接收 本类字节码方法得到的 注解类的字节码文件。
System.out.println(annotation.color());//通过自定义属性得到方法值。
//得到结果就证实了这个类身上确实有注解。
System.out.println(annotation.value());
System.out.println(annotation.arrayattr().length);
System.out.println(annotation.lamp().nextlamp()); //虽然最上面的注解里面没有写上灯,但是属性里面有。
System.out.println(annotation.annotationattr().value());
}
}
//如果有这么一个方法,很多人使用,而一部分人不再去用它,为了照顾新老用户。可以注解
@Deprecated
public static void sayHello(){
System.out.println("hi,唐");
}
}
package Java5新特性注解;
public @interface MetaAnnotation {
String value();
}
<---------------------- ASP.Net+Android+IOS开发、.Net培训、期待与您交流! ----------------------/p>