1.注解 (Annotation)是从 JDK5. 开始引入,以“@注解名”在代码中存在。例如:
@Override
@Deprecated
@SuppressWarnings(value="unchecked”)
Annotation 可以像修饰一样被使用,可用于修饰包、类、构造器、方法、成员变量、参数、局部变量的声明。
还可以添加一些参数值,这些信息被保存在Annotation 的“name=value”对中。
注解可以在类编译、运行时进行加载,体现不同的功能。
2.注解与注释
注解也可以看做是一种注释,通过使用 Annotation,程序员可以在不改变原有逻辑的情况下,在源文件中嵌入-些补充信息。但是,注解,不同于单行注释和多行注释。
。对于单行注释和多行注释是给程序员看的。
。而注解是可以被编译器或其他程序读取的。程序还可以根据注解的不同,做出相应的处理。
3.主解的重要性
在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE/Android中注解占据了更重要的角色,例如用来配置应用程序的任何切面,代替JavaEE旧版中所遗留的 繁代码和XML配置等。
未来的开发模式都是基于注解的,JPA是基于注解的,Spring2.5以上都是基于注解的,Hibernate3.x以后也是基于注解的,Struts2有一部分也是基于注解的了。注解是一种趋势,一定程度上可以说:框架 注解 + 反射+设计模式。
@Override 限定重写父类方法,该注解只能用于方法
@Deprecated 用于表示所修饰的元素(类,方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择
@SuppressWarnings(value="unchecked”) :抑制编译器警告
1.Annotation的理解
>注解(Annotation)是从·JDK5.开始引入,以”@注解名、”在代码中存在。
Annotation 可以像修饰符一样被使用,可用于修饰包、类、构造器、方法、成员变量、参数、局部变量的声明。
还可以添加一些参数值,这些信息被保存在 Annotation 的“name=value” 对中。
注解可以在类编译、运行时进行加载,体现不同的功能。
2。注解的应用场景:
示例1:生成文档相关的注解
示例2:在编译时进行格式检查(JDK内置的三个基本注解)
示例3:跟踪代码依赖性,实现替代配置文件功能
3,Java基础涉及到的三个常用注解
@Override: 限定重写父类方法,该注解只能用于方法
@Deprecated:用于表示所修饰的元素(类,方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择
@SuppressWarnings: 抑制编译器警告
4.自定义注解
以@SuppressWarnings为参照,进行定义
5.元注解的理解
元注解,对现有的注解进行解释说明的注解。
拓展: 元数据。
String name = “Tom”
框架 =注解 +反射 +设计模式
package Test0615;
public class AnnotationTest {
public static void main(String[] args) {
Person3 p1 = new Student("梨",20);
System.out.println(p1.name);
System.out.println(p1);
}
}
class Person3{
String name;
int age;
public Person3(){
}
public Person3(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Test0615.Person3{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
public void eat() {
System.out.println("人吃饭");
}
public void walk(){
System.out.println("人走路");
}
}
@MyAnnotation("class")
class Student extends Person3{
public Student(String name, int age) {
super(name, age);
}
//如果有注解,就能提示是重写
@MyAnnotation//
public void eat(){
System.out.println("学生吃饭");
}
public void walk(){
System.out.println("学生走路");
}
}
注释:package Test0615;
public @interface MyAnnotation {
String[] value() default "hello";
}