Java-注解

注解概念

  • 概念:说明程序。给计算机看的
  • 注释:用文字描述程序。给程序员看的
  • 总结:
    • JDK1.5之后的新特性
    • 用来说明程序的
    • 使用注解:@注解名称

注解作用分类

  • 编写文档:通过代码里标识的注解生成文档【生成文档doc文档】
  • 代码分析:通过代码里标识的注解对代码进行分析【使用反射】
  • 编译检查:通过代码里标识的注解让编译器能够实现基本的编译检查【Override】

JDK中预定义的一些注解

  1. @Override:
    检测被该注解标注的方法是否是集成父类的;
  2. @Deprecated
    该注解标注的内容,表示已过时。IDE中用划横线显示;
  3. @SuppressWarnings
    • 压制警告,用来消除不必要的警告。
    • 一般传参数all @SuppressWarnings(“all”)

自定义注解

  1. 格式:
	元注解
	public @interface 注解名称{
			属性列表;	
	} 
  1. 本质:注解本质上就是一个接口,该接口继承Annotation接口
    public interface MyAnno extends java.lang.annotation.Annotation{}

  2. 属性:接口中的抽象方法

    • 要求:
      • 属性的返回值类型有下列取值:
        • 基本数据类型
        • String
        • 枚举
        • 注解
        • 以上类型的数组
      • 定义了属性,在使用时需要给属性赋值
        • 如果定义属性时,使用default关键字给属性默认初始化值,则使用注释时,可以不进行属性的赋值。
        • 如果只有一个属性需要赋值,并且属性的名称时value,则value可以省略,直接定义值即可。
        • 数组赋值时,值使用{}包裹。如果数组中只有一个值,则{}省略。
  3. 元注解:描述注解的注解。

    • @Target: 描述注解能够作用的位置
      • ElementType取值:
        • TYPE:可以作用于另类上
        • METHOD:可以作用于方法上
        • FIELD:可以作用于成员变量上
    • @Retention:描述注解被保留的阶段
      • @Retention(RetentionPolicy.CLASS):当前被描述的注解,会保留到class字节码文件中,并被JVM读取到
    • @Documented:描述注解是否被抽取到api文档中
    • @Inherited:描述注解是否被子类继承

在程序中使用(解析)注解:获取注解中定义的属性值

  1. 获取注解定义位置的对象(Class、Method、Field)
  2. 获取指定的注解
    (getAnnotation(Class))
//	其实就是在内存中生成了一个该注解接口的子类实现对象
		public class ProImpl implements Pro{
				public String className(){
					return "xxx.xxx.Demo";
				}
				public Sting methodName(){
					return "show";
				}
	}
  1. 调用注解中的抽象方法获取配置的属性值

小结

  1. 以后大多数时候,我们会使用注解,而不是自定义注解。
  2. 注解给谁用?
    • 编译器
    • 给解析程序
  3. 注解不是程序的一部分,可以理解为注解就是一个标签。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值