学习注解s

注解

注释:给人看,用于提醒程序员
注解:给程序看的,它拥有一定的功能
注解是JDK1.5之后才有
注解的格式:@关键词
注解的位置:类上、方法上、属性上

注解的分类

1、编译检查

如果写法错误,则编译报错

1 @Override : 表明该方法重写的父类的方法
2 @Deprecated : 标记过时
3 @SuppressWarnings("serial") :  抑制警告

2、文档

通过注解生成文档
/**
 * 
 * @author 老王 
 * @version 1.0
 * 
 *
 */
public  class Father {
   
	/**
	 * 
	 * @param a  加数1
	 * @param b  加数2
	 * @return   两数之和
	 */
	public int add(int a,int b){
   
		return a+b;
	};
}
通过CMD命令生成文档API
	javadoc xx.java
	javadoc *.java
步骤:
	1 创建文件夹,把需要生成文档的java文件放进该文件夹中
	2 通过cmd切换到当前文件夹,最后通过javadoc命令生成文档

3、自定义

//语法:新建自定义注解
public @interface 注解名{

	方法列表;
}
注解的底层是一个接口,它继承了Annotation接口
通过反编译证明:
1  javac xx.java
2  javap xx.class
public interface MyAnno extends java.lang.annotation.Annotation {
}
注解的属性
1 这里的属性实际上指的是接口中的方法的声明
2 方法必须有返回值
3 返回值类型也是有规定的:
	3.1  8大基本数据类型
	3.2  String
	3.3  枚举
	3.4  注解
	3.5  返回以上类型的数组形式
使用自定义注解

语法:在类上、方法上、属性上都能使用

如果该注解没有任何属性:@注解名
如果该注解有任何属性: @注解名(属性1=值1,属性2=值2.....)
public @interface  MyAnno {
   
	public  int  x1(); // 八大基本类型
	public  String  x2();//String类型
	public  Stu  x3();//枚举类型
	public  MyAnno2  x4();//注解类型
	public  int[]  x5();//以上类型的数组类型
}
//使用:
@MyAnno(x1=3,x2="abc",x3=Stu.jack,x4=@MyAnno2,x5={
   1,2,3})
public class User {
   }

我们可以把定义在注解中的属性当作形参
而使用注解时传递的值当作实参

关于属性的特殊案例
1 如果数组中的元素只有一个,则可以省去{}
2 我们可以给属性设置默认值,设置默认值后,在使用注解是可以不用管该属性
3 如果属性名是value,并且该注解只有这一个属性或者该注解的其他属性都有默认值,则在使用注解时可以省去value
//定义
public @interface  MyAnno {
   
	public  String[]  value();
}
//使用:
@MyAnno(value={
   "abc"})
public class User {
   }
//简写:
@MyAnno("abc")
public class User {
   }
元注解
用于约束注解的注解
位置࿱
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值