一、获取应用笔记

常常会遇到这种情况

package Tokyo.Hot;
public class Demo { public static void main(String[] args) { new Thread().stop();
//画一条线。非常明显是过时的方法
}
}

这是过时的方法。这时就要用到注解。告诉编译器,我知道这是过时的,我就喜欢用



@SuppressWarnings("deprecation")   deprecation。过时的,背单词

package Tokyo.Hot;

public class Demo {

	@SuppressWarnings("deprecation")
public static void main(String[] args) { new Thread().stop(); }
}

注意:一个注解就是一个类



当你曾经写好了一个类的方法,可是如今不想用了。为了不给用这种方法的人造成困扰,那么就能够在方法上加入一个@Deprecated,这是



一个过时的方法

public class Demo {

	public static void main(String[] args) {

		Out();
}
@Deprecated
private static void Out() {
System.out.println("Hello,World!");
}
}

HashSet,须要复写equals方法,可是equals(),參数是Object类型。可是一不小心,写成别的类,这个错误非常不easy找到,那么这时,就须要用到注解@Override,复写

new Thread(new Runnable() {
@Override
public int run() {
}}).start();

注解,相当于一种标记,在包、类、方法、变量、字段等上面加入了这样的标记,告诉编译器。你依照我的标记採取对应的动作



OK。注解的皮毛。已然了解!



二、注解的定义和反射调用



我们想使用某个类,那么就必须先设计写好那个类,注解也是如此,我们想使用某个注解,那么我们也必须提前先设计写好那个注解



1.定义注解类:

public @interface MyTokyo {} 和定义接口的方式是一样的



2.应用了注解的类: 

@MyTokyo

class MyClass{},检查这个类上是否有这个注解



3.对"应用注解的类"进行反射

要对一个类进行检查,肯定用到反射

@MyTokyo
public class Demo { public static void main(String[] args) {
Boolean flag = Demo.class.isAnnotationPresent(MyTokyo.class);//检查是否有注解
if(flag){
MyTokyo myTokyo = (MyTokyo) Demo.class.getAnnotation(MyTokyo.class);//得到这个注解对象
System.out.println(myTokyo);
}
}
}

会发现什么也不打印

在自己定义的注解上加入注解,注解的注解->源注解

@Retention(RetentionPolicy.RUNTIME)

public @interface MyTokyo {}

@Retention(RetentionPolicy.RUNTIME)的意义,也就是告诉编译器,将自己定义的注解保留到执行期。由于自己定义的注解可能在编译期,就清除了。javac把源文件编译成class,可能就把源程序的注解就去掉了。还有可能是在类载入器把类载入到内存时,类中的注解是否保留,

也是问题。



特别注意:class文件里的东西。不是字节码,仅仅有类载入器把class文件进行安全检查等一系列的处理后。载入到内存的二进制才是字节码



一个注解的生命周期有三个阶段:

1.java源文件  2.class文件  3.内存中的字节码



所以@Retention就有三种取值:



(RetentionPolicy.SOURCE 源文件阶段)



(RetentionPolicy.CLASS class文件阶段)



(RetentionPolicy.RUNTIME 执行阶段)



而默认值是CLASS阶段



@Override的默认值是(RetentionPolicy.SOURCE 源文件阶段)



@SuppressWarnings的默认值是(RetentionPolicy.SOURCE 源文件阶段)



@Deprecated的默认值 (RetentionPolicy.RUNTIME 执行阶段)





继续,在自己主动注解上再加一个注解@Target



@Retention(RetentionPolicy.SOURCE)



@Target(ElementType.METHOD)

public @interface MyTokyo {}



作用:告诉编译器,自己定义的注解仅仅能载入方法上



要想使注解在类和方法都能使用

@Retention(RetentionPolicy.SOURCE)



@Target({ElementType.METHOD,ElementType.TYPE})



public @interface MyTokyo {}



注意是TYPE,类型。不不过class,接口都能够,所以用TYPE更贴切,而不用class





三、为注解添加属性





注解之所以强大,是由于其的属性



注解非常像接口,而注解的属性就非常像方法

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD,ElementType.TYPE}) public @interface MyTokyo {
String color();//注解有个属性color,返回字符串
}



那么主函数就能够是设置属性值

@MyTokyo(color="red")

public class Demo {

	public static void main(String[] args) {
Boolean flag = Demo.class.isAnnotationPresent(MyTokyo.class);//检查是否有注解
if(flag){
MyTokyo myTokyo = (MyTokyo) Demo.class.getAnnotation(MyTokyo.class);//得到这个注解对象
System.out.println(myTokyo.color());
}
}
}



打印red,这就是为注解加入属性,在用的时候,给它设置属性值

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD,ElementType.TYPE}) public @interface MyTokyo {
String color() default "blue";//默认是blue
String value();
} @MyTokyo(color="red",value="ax")//属性没有设置默认的时候。全部属性必须都要写 public class Demo {
@MyTokyo("xc")//由于color设置了缺省值,所以能够仅仅写xc代表value的属性值。能够不写value
public static void main(String[] args) {
Boolean flag = Demo.class.isAnnotationPresent(MyTokyo.class);//检查是否有注解
if(flag){
MyTokyo myTokyo = (MyTokyo) Demo.class.getAnnotation(MyTokyo.class);//得到这个注解对象
System.out.println(myTokyo.color());
}
}
}

数组类型的属性

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD,ElementType.TYPE}) public @interface MyTokyo {
String color() default "blue";
String value();
int[] arr() default {3,4,5};
}

注意数组的元素假设仅仅有一个的话,arr=1。能够不写大括号

@MyTokyo(color="red",value="ax",arr={1,2,3,4})

public class Demo {
@MyTokyo("xc")
public static void main(String[] args) {
Boolean flag = Demo.class.isAnnotationPresent(MyTokyo.class);
if(flag){
MyTokyo myTokyo = (MyTokyo) Demo.class.getAnnotation(MyTokyo.class);//得到这个注解对象
System.out.println(myTokyo.color());
System.out.println(myTokyo.value());
System.out.println(myTokyo.arr().length);
}
}
}

枚举类型的属性



//定义一个枚举类

public class Week {
private Week(){}
public final static Week SUN = new Week();
public final static Week MON = new Week();
public Week nextDay(){
return this==SUN? MON : null;
}
public String toString(){
return this==MON ? "MON":"SUN";
}
public enum WeekDay{
SUN,MON;
}
}

定义枚举类型的属性

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD,ElementType.TYPE}) public @interface MyTokyo {
String color() default "blue";
String value();
Week.WeekDay Day() default Week.WeekDay.SUN;//定义枚举类型的属性
int[] arr() default {3,4,5};
MyAnotaion2 anotaionArr() default @MyAnotaion2("x");
} @MyTokyo(anotaionArr=@MyAnotaion2("wjw"),color="red",value="ax",arr={1,2,3,4}) public class Demo {
@MyTokyo(value="xc",Day=Week.WeekDay.SUN)
public static void main(String[] args) {
Boolean flag = Demo.class.isAnnotationPresent(MyTokyo.class);
if(flag){
MyTokyo myTokyo = (MyTokyo) Demo.class.getAnnotation(MyTokyo.class);//得到这个注解对象 System.out.println(myTokyo.Day().name());
} }
}

注解类型的属性

public @interface MyAnotaion2 {
String value();
} @Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD,ElementType.TYPE}) public @interface MyTokyo {
String color() default "blue";
String value();
int[] arr() default {3,4,5};
MyAnotaion2 anotaionArr() default @MyAnotaion2("x");//返回一个MyAnotaion2注解的注解类型属性
}



注解中的注解类型属性

@MyTokyo(anotaionArr=@MyAnotaion2("wjw"),color="red",value="ax",arr={1,2,3,4})

public class Demo {
@MyTokyo("xc")
public static void main(String[] args) {
Boolean flag = Demo.class.isAnnotationPresent(MyTokyo.class);
if(flag){
MyTokyo myTokyo = (MyTokyo) Demo.class.getAnnotation(MyTokyo.class);//得到这个注解对象
System.out.println(myTokyo.color());
System.out.println(myTokyo.value());
System.out.println(myTokyo.arr().length);
System.out.println(myTokyo.anotaionArr().value());
}
}
}



注解的属性返回值还能够是8个基本类类型、class、所有类型的只是阵列

通过查看文件,以便更好地了解的注释。Notes应用也越来越广泛,以后要注意这个应用方面



Java加深理解有关注释的更多相关文章

  1. 加深理解Java异常概念并熟记5个最常见的运行时异常

    加深理解Java异常概念并熟记5个最常见的运行时异常 说明Error与Exception的联系和区别有哪些? 列举最常见的5个运用时异常. 1.Error和Exception的联系和区别: Error ...

  2. 从Java视角理解CPU缓存(CPU Cache)

    从Java视角理解系统结构连载, 关注我的微博(链接)了解最新动态众所周知, CPU是计算机的大脑, 它负责执行程序的指令; 内存负责存数据, 包括程序自身数据. 同样大家都知道, 内存比CPU慢很多 ...

  3. Effective Java通俗理解(持续更新)

    这篇博客是Java经典书籍<Effective Java(第二版)>的读书笔记,此书共有78条关于编写高质量Java代码的建议,我会试着逐一对其进行更为通俗易懂地讲解,故此篇博客的更新大约 ...

  4. Effective Java通俗理解(下)

    Effective Java通俗理解(上) 第31条:用实例域代替序数 枚举类型有一个ordinal方法,它范围该常量的序数从0开始,不建议使用这个方法,因为这不能很好地对枚举进行维护,正确应该是利用 ...

  5. Effective Java通俗理解(上)

    这篇博客是Java经典书籍<Effective Java(第二版)>的读书笔记,此书共有78条关于编写高质量Java代码的建议,我会试着逐一对其进行更为通俗易懂地讲解,故此篇博客的更新大约 ...

  6. java全栈day01-03注释、关键字与标识符

    通常我们需要在源代码中添加文字用来对进行代码解释说明,但这些文字并不是Java代码的语法,会导致编译出错.这时我们可以使用注释来完成这一事项! 在编译时,编译器会忽略注释的存在,就好像注释内容不存在一 ...

  7. JAVA 需要理解的重点 一

    需要理解的重点内容有: JVM内存管理机制和垃圾回收机制(基本每次面试都会问,一定要搞得透彻) JVM内存调优(了解是怎么回事,一般做项目过程中使用较多) 设计模式(熟悉常见设计模式的应用场景,会画类 ...

  8. Myeclipse中导入项目后java类中汉字注释出现乱码问题(已解决)

    今天重装系统,安装了新的Myeclipse后,导入之前的项目后,,出现了乱码问题.乱码问题主要是java类中的注释,而jsp页面中汉字却完好如初: 右键项目,查看项目的编码格式,UTF-8,把java ...

  9. [java] 深入理解内部类: inner-classes

    [java] 深入理解内部类: inner-classes // */ // ]]>   [java] 深入理解内部类: inner-classes Table of Contents 1 简介 ...

随机推荐

  1. LeetCode 53 Spiral Matrix

    Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...

  2. 【夸QT在十五】ctkPluginFrameWork插件系统Windows编译器

    采用ctkPluginFramework作为一个插件系统开发框架确实有很多优点. 有些车站最近收到的一封信,每个人都想用ctkPluginFramework但我不知道如何建立,本教程对谈ctkPlug ...

  3. C++学习笔记33 转换操作符

    有时候,我们要转换为类类型和类类型,同时,这两个类继承关系不存在,这时候我们就需要一些所谓的转换操作符运营商. 一个简单的例子.类别A转换为int种类 #include <iostream> ...

  4. Nubia Z5S 官方4.4 201内測版 内核版本号信息

    从egl推断内核的的版本号: OpenGL ES Shader Compiler Version: E031.24.00.14 Build Date: 04/29/14 Tue Local Branc ...

  5. Lua 服务器与客户端实例(转)

    =============================================================== 服务器,main.lua ======================= ...

  6. Java 大数类

    划分结果存在数组.供应商下标0 在剩下的标记1 import java.math.BigInteger; import java.util.Scanner; public class Main { p ...

  7. 构造NFS

    一.设备nfs-utils 伺服器: [root@server05 ftp]# yum install nfs-utils 这时会自己主动安装rpcbind需将此服务重新启动nfs服务才干启动 cli ...

  8. virus.win32.parite.H查杀病毒的方法

    virus.win32.parite.H病毒的查杀方法 昨天电脑中了virus.win32.parite.H病毒,搞了2个多小时最终搞定了.以下记录下我的解决方法. 第一步:下载Win32.Parit ...

  9. 手提wifi双卡配置+window7同时多用户远程+有些公司限制网络环境方案

    该公司只提供几台机器,同时限制并连接到内部办公网络的机, 我们更多的临时工作人员,项目紧张,而另一种是太麻烦了申请, 当被问及其他网络管理,说没有变通方法. 在我的尝试,最后,找到一个解决方案; 解决 ...

  10. 低压电力采集平台DW710C与PC沟通

    集电极485接口RS-485与RS-232转换模块485端相连.RS-485与RS-232转换模块232通过串行电缆末端PC的232串口.我们通过书面沟通PC通信软件来实现双方并执行收购方案. 1)上 ...