注解概述

注解的本质是一个接口,注解主要有三种用途,标记,编译检测,抽取API

## 注解:
	* 概念:说明程序的。给计算机看的
	* 注释:用文字描述程序的。给程序员看的

	* 定义:注解(Annotation),也叫元数据。一种代码级别的说明。它是JDK1.5及以后版本引入的一个特性,与类、接口、枚举是在同一个层次。它可以声明在包、类、字段、方法、局部变量、方法参数等的前面,用来对这些元素进行说明,注释。
	* 概念描述:
		* JDK1.5之后的新特性
		* 说明程序的
		* 使用注解:@注解名称
		* * 作用分类:
		①编写文档:通过代码里标识的注解生成文档【生成文档doc文档】
		②代码分析:通过代码里标识的注解对代码进行分析【使用反射】比如用于传递类的全类名以及方法
		③编译检查:通过代码里标识的注解让编译器能够实现基本的编译检查【Override】


	* JDK中预定义的一些注解
		* @Override	:检测被该注解标注的方法是否是继承自父类(接口)* @Deprecated:该注解标注的内容,表示已过时
		* @SuppressWarnings:压制警告
			* 一般传递参数all  @SuppressWarnings("all")

	* 自定义注解
		* 格式:
			元注解
			public @interface 注解名称{
				属性列表;
			}

		* 本质:注解本质上就是一个接口,该接口默认继承Annotation接口
			* public interface MyAnno extends java.lang.annotation.Annotation {}

 */
public @interface Anno {
    //注解的本质是接口,接口中可以定义的,注解也同样可以定义
    //注解的抽象方法称为属性,因为在使用抽象方法时,需要给抽象方法赋值
    //抽象方法的返回值类型:基本数据类型 字符串 枚举 注解 以及上述的数组
    public abstract int eat();
    public abstract String sayHallow();
    public abstract String[] s();
    public abstract int value();
    public abstract int num() default 10;//默认赋值,不需要等于号

}

package cn.icast.day23.DemoAnnotation;
@Anno(eat=1,sayHallow ="小明",s={"a","b"},value=10)
public class Demo {
    public static void main(String[] args) {


    }
}
/*
2. 定义了属性,在使用时需要给属性赋值
					1. 如果定义属性时,使用default关键字给属性默认初始化值,则使用注解时,可以不进行属性的赋值。
					2. 如果只有一个属性需要赋值,并且属性的名称是value,则value可以省略,直接定义值即可。
					3. 数组赋值时,值使用{}包裹。如果数组中只有一个值,则{}可以省略
 */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值