JDK1.5后JAVA引入了注解,常用的注解有Override,Deprecated,SuppressWarnings。
Override用来验证当前书写的方法是否是重写的方法,如果不是则报编译错误提示。
Deprecated用来设置方法为过时的方法。
SuppressWarnings用来去掉编译中的警告错误,但他需要一个参数SuppressWarnings("uncheacked")。
当然我们也可以定义自己的注解,定义的方法是:
1、创建一个annotation类,比如:
public @interface AnnotationTest{ }
注意这个“接口”在写法上很特别,AnnotationTest就是我们创建好的注解了,我们将该注解使用于任何地方都没有错,但是这是没有意义的,因为他什么功能都没实现
2、填加属性,我们看到在SuppressWarnings注解中必须填加一个属性才能编译通过,这是怎么实现的呢?
String value();初看像一个方法,其实他是一个属性,并且如果属性名字是value的话,在外面传递参数的时候就直接写参数的值就行了,当然我们也可以不设置为value,比如我们设置为String rule();这时我们在使用AnnotationTest注解的时候就必须写成AnnotationTest(rule="")来设置参数了。
annotation中的参数类型不是任意的,只能是String,Enum,Annotation,Class和一维数组。
3、填加规则,我们发现Override只能用于方法而不能用于其他地方,但我们自己定义的注释却能用于所有的地方,那有什么办法也控制下自定义的作用范围呢?
我们在自定义的注解中使用系统注解来规范,比如:
@Inherited
@Documented
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface AnnotationTest{ }
我们看到在自定义的注解中我们加上了很多的规则,其中:
Target注解就是设置作用范围的,只需要将参数设置为ElementType.METHOD,那该注解就只能对方法起作用了;
Retention注解是设置该注解存在的状态,他有三种值,CLASS、RUNTIME、SOURCE,默认为CLASS;
Documented注解是生成DOC文档才起作用,表示生成该注解,否则不生成;
Inherited注解是继承关系中的,使子类在重写父类方法的时候,该方法的注解同样使用于子类中,但是要注意,目前研究过的只对类注解有效,对只能运用于方法的注解好象不行。
分享到:
相关推荐
赠送jar包:jakarta.annotation-api-1.3.5.jar; 赠送原API文档:jakarta.annotation-api-1.3.5-javadoc.jar; 赠送源代码:jakarta.annotation-api-1.3.5-sources.jar; 赠送Maven依赖信息文件:jakarta.annotation...
赠送jar包:javax.annotation-api-1.2.jar; 赠送原API文档:javax.annotation-api-1.2-javadoc.jar; 赠送源代码:javax.annotation-api-1.2-sources.jar; 赠送Maven依赖信息文件:javax.annotation-api-1.2.pom;...
赠送jar包:jakarta.annotation-api-1.3.5.jar; 赠送原API文档:jakarta.annotation-api-1.3.5-javadoc.jar; 赠送源代码:jakarta.annotation-api-1.3.5-sources.jar; 赠送Maven依赖信息文件:jakarta.annotation...
赠送jar包:javax.annotation-api-1.3.2.jar; 赠送原API文档:javax.annotation-api-1.3.2-javadoc.jar; 赠送源代码:javax.annotation-api-1.3.2-sources.jar; 赠送Maven依赖信息文件:javax.annotation-api-...
赠送jar包:geronimo-annotation_1.0_spec-1.1.1.jar; 赠送原API文档:geronimo-annotation_1.0_spec-1.1.1-javadoc.jar; 赠送源代码:geronimo-annotation_1.0_spec-1.1.1-sources.jar; 赠送Maven依赖信息文件:...
javax.annotation-3.0.jar javax.annotation-3.0.jar javax.annotation-3.0.jar
@androidx.annotation.NonNull 缺失的兼容、androidx.annotation兼容包
赠送jar包:mybatis-plus-annotation-3.2.0.jar; 赠送原API文档:mybatis-plus-annotation-3.2.0-javadoc.jar; 赠送源代码:mybatis-plus-annotation-3.2.0-sources.jar; 赠送Maven依赖信息文件:mybatis-plus-...
赠送jar包:javax.annotation-api-1.2.jar; 赠送原API文档:javax.annotation-api-1.2-javadoc.jar; 赠送源代码:javax.annotation-api-1.2-sources.jar; 赠送Maven依赖信息文件:javax.annotation-api-1.2.pom;...
JDK9及以上版本没有javax.annotation-api-***.jar包 ,无法使用注解:@Resource JDK新特性,高版本JDK没有自带的javax(java扩展包)了。或者是使用的JDK不完整。 下载javax.annotation.jar包,导入到lib文件夹下,...
spring 注解初始化,初始化开始@postconstruct 对象销毁@predestroy javax.annotation.jar文件
赠送jar包:javax.annotation-api-1.3.2.jar; 赠送原API文档:javax.annotation-api-1.3.2-javadoc.jar; 赠送源代码:javax.annotation-api-1.3.2-sources.jar; 包含翻译后的API文档:javax.annotation-api-...
详解 Spring 3.0 基于 Annotation 的依赖注入实现。。详解 Spring 3.0 基于 Annotation 的依赖注入实现。。
1.Annotation注解的介绍和使用
完整的android.support.annotation.jar包含Nullable、Keep、XmlRes、TransitionRes、WorkerThread等共49个类
github链接链接:https://github.com/springzfx/point-cloud-annotation-tool 在windows平台编译完成后的exe和dll文件,可以直接打开使用,并对原项目进行了优化,增加了列表和标注文件的显示功能,标注起来更快,...
文件中包含javax.annotation的jar包,用来解决@Resource注解无法导入依赖。Resource注解无法导入依赖使用javax.annotation的注解类,这是他的jar包。
Java annotation 什么是java annotation?annotation 的7种标注类型。nnotation提供了一条与程序元素关联任何信息或者任何元数据(metadata)的途径。从某些方面看,annotation就像修饰符一样被使用,并应用于包、...
androidx-annotation-1.2.0.jar
花了些时间做了一个实验,彻底弄懂了spring Annotation注入的方式。凡带有@Component,@Controller,@Service,@Repository 标志的等于告诉Spring这类将自动产生对象,而@Resource则等于XML配置中的ref,告诉spring此处...