一、定义Java文件叫做Annotation,用@interface表示。
br/>Java文件叫做Annotation,用@interface表示。
二、元注解
@Retention 从源代码中可以看出,主要用于提示注解要保留多长时间
package java.lang.annotation;
/**
创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站设计、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的启东网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
- Indicates how long annotations with the annotated type are to
- be retained. If no Retention annotation is present on
- an annotation type declaration, the retention policy defaults to
- {@code RetentionPolicy.CLASS}.
A Retention meta-annotation has effect only if the
- meta-annotated type is used directly for annotation. It has no
- effect if the meta-annotated type is used as a member type in
- another annotation type.
- @author Joshua Bloch
- @since 1.5
- @jls 9.6.3.2 @Retention*/
@Documented
br/>*/
@Documented
br/>@Target(ElementType.ANNOTATION_TYPE)
/**
- Returns the retention policy.
- @return the retention policy
*/
RetentionPolicy value();
}
有三种取值:
RetentionPolicy.SOURCE 将会被编译器抛弃
RetentionPolicy.CLASS 注解会被编辑器保留在类文件中,但是会被vm抛弃
RetentionPolicy.RUNTIME 注解会被编辑器保留在类文件中,也会被vm保留,所以可以通过反射读取。
package java.lang.annotation;
/**
- Annotation retention policy. The constants of this enumerated type
- describe the various policies for retaining annotations. They are used
- in conjunction with the {@link Retention} meta-annotation type to specify
- how long annotations are to be retained.
- @author Joshua Bloch
- @since 1.5
*/
public enum RetentionPolicy {
/**
- Annotations are to be discarded by the compiler.
*/
SOURCE,
/** - Annotations are to be recorded in the class file by the compiler
- but need not be retained by the VM at run time. This is the default
- behavior.
*/
CLASS,
/** - Annotations are to be recorded in the class file by the compiler and
- retained by the VM at run time, so they may be read reflectively.
- @see java.lang.reflect.AnnotatedElement
*/
RUNTIME
}
@Target 用于提示该注解使用的地方@Documented
br/>@Documented
br/>@Target(ElementType.ANNOTATION_TYPE)
/** - Returns an array of the kinds of elements an annotation type
- can be applied to.
- @return an array of the kinds of elements an annotation type
- can be applied to
*/
ElementType[] value();
}
其中ElementType的取值有下面十种:
ElementType.TYPE 用于类,接口(包括注解)或者枚举类型
ElementType.FIELD 用于属性字段包括枚举常量
ElementType.METHOD 用于方法级别
ElementType.PARAMETER 用于参数声明
ElementType.CONSTRUCTOR 用于构造函数声明
ElementType.LOCAL_VARIABLE 用于局部变量声明
ElementType.ANNOTATION_TYPE 用于注解类型声明
ElementType.PACKAGE 用于包声明
ElementType.TYPE_PARAMETER 用于泛型声明
ElementType.TYPE_USE 用于任意类型声明
public enum ElementType {
/ Class, interface (including annotation type), or enum declaration */
TYPE,
/* Field declaration (includes enum constants) /
FIELD,
/Method declaration */
METHOD,
/ Formal parameter declaration */
PARAMETER,
/* Constructor declaration /
CONSTRUCTOR,
/Local variable declaration */
LOCAL_VARIABLE,
/ Annotation type declaration */
ANNOTATION_TYPE,
/* Package declaration /
PACKAGE,
/ - Type parameter declaration
- @since 1.8
*/
TYPE_PARAMETER,
/** - Use of a type
- @since 1.8
*/
TYPE_USE
}
@Documented 将注解包含在Javadoc中
package java.lang.annotation;
/**
- Indicates that annotations with a type are to be documented by javadoc
- and similar tools by default. This type should be used to annotate the
- declarations of types whose annotations affect the use of annotated
- elements by their clients. If a type declaration is annotated with
- Documented, its annotations become part of the public API
- of the annotated elements.
- @author Joshua Bloch
- @since 1.5*/
@Documented
br/>*/
@Documented
br/>@Target(ElementType.ANNOTATION_TYPE)
}
@Inherited 允许子类继承父类
package java.lang.annotation;
/** - Indicates that an annotation type is automatically inherited. If
- an Inherited meta-annotation is present on an annotation type
- declaration, and the user queries the annotation type on a class
- declaration, and the class declaration has no annotation for this type,
- then the class's superclass will automatically be queried for the
- annotation type. This process will be repeated until an annotation for this
- type is found, or the top of the class hierarchy (Object)
- is reached. If no superclass has an annotation for this type, then
- the query will indicate that the class in question has no such annotation.
Note that this meta-annotation type has no effect if the annotated
- type is used to annotate anything other than a class. Note also
- that this meta-annotation only causes annotations to be inherited
- from superclasses; annotations on implemented interfaces have no
- effect.
- @author Joshua Bloch
- @since 1.5
- @jls 9.6.3.3 @Inherited*/
@Documented
br/>*/
@Documented
br/>@Target(ElementType.ANNOTATION_TYPE)
}
三、自定义注解的使用
创建一个自定义注解
import java.lang.annotation.*;
/** - Created Date: 2019/3/1
创建自定义注解
*/
@Target({ ElementType.METHOD, ElementType.TYPE })@Retention(RetentionPolicy.RUNTIME)
br/>@Retention(RetentionPolicy.RUNTIME)
public @interface TestAnnotation {
String value();
}
通过反射获取注解
public class Test {
@TestAnnotation(value = "测试方法")
public static void main(String args[]){
try {
Class c=Test.class;
Method[] methods=c.getDeclaredMethods();
for(Method method:methods){
Annotation[] annotations=method.getDeclaredAnnotations();
for(Annotation annotation:annotations){
TestAnnotation testAnnotation= (TestAnnotation) annotation;
System.out.println(testAnnotation.value());
}
}
} catch (ClassNotFoundException e) {e.printStackTrace();
}
}
}
四、web开发中的运用
在web开发中,权限控制非常重要,所以有些接口会限制必须登录之后才能访问,但是个别接口并没有这种限制。一种方式是把需要过滤的ThinkMarkets代理申请www.kaifx.cn/broker/thinkmarkets.html接口或者方法配置在文件中,每次请求时在拦截器中根据请求的路径与配置文件中的对比过滤。其实还有另外一种方式就是通过注解方式。
定义一个注解NoLogin
@Target(ElementType.METHOD)
br/>e.printStackTrace();
}
}
}
四、web开发中的运用
在web开发中,权限控制非常重要,所以有些接口会限制必须登录之后才能访问,但是个别接口并没有这种限制。一种方式是把需要过滤的ThinkMarkets代理申请www.kaifx.cn/broker/thinkmarkets.html接口或者方法配置在文件中,每次请求时在拦截器中根据请求的路径与配置文件中的对比过滤。其实还有另外一种方式就是通过注解方式。
定义一个注解NoLogin
@Target(ElementType.METHOD)
br/>@Documented
}
标注在方法上
在拦截器中判断方法上是否有NoLogin注解
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception {
//支持两种方式过滤 1、注解方式 添加@NoLogin注解
HandlerMethod handlerMethod= (HandlerMethod) o;
NoLogin noLogin=handlerMethod.getMethod().getDeclaredAnnotation(NoLogin.class);
if(null!=noLogin){
return true;
}
}
五、java内置的注解
除了上述的四个元注解,java还内置了另外三个注解:
@Override 它没有任何的属性,不能存储任何其他信息。它只能作用于方法之上,编译结束后将被丢弃。在java编译器编译成字节码的时候,一旦发现某个方法被这个注解标识过,就会匹配父类中是否存在同一方法,如果不存在就回编译失败。@Target(ElementType.METHOD)
br/>@Target(ElementType.METHOD)
public @interface Override {
}
@Deprecated 弃用的注解@Documented
br/>@Documented
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})
public @interface Deprecated {
}
@SuppressWarnings 压制警告,比如某段代码中存在过时的方法,那么在编译过程中,会有warn警告,如果不想出现类似的警告,可在方法上添加这个注解。这个注解有一个value的值,这个value表示需要压制的警告类型。
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})@Retention(RetentionPolicy.SOURCE)
br/>@Retention(RetentionPolicy.SOURCE)
/**
网页名称:java自定义注解的使用
网页URL:
http://www.cdkjz.cn/article/joiejg.html