Java注解@Inherited的使用

在看定义注解的相关文章的时候,看到这个@Inherited注解,简单的说明并没有真正搞懂是什么意思。在网上搜索了一些相关的内容,现在把一篇文章转载过来。以便后面使用。
文章出处,转载地址:(http://zy19982004.iteye.com/blog/1979520),在此特别感谢!

@Inherited:允许子类继承父类的注解。

二.代码

@Target(ElementType.TYPE)  
@Retention(RetentionPolicy.RUNTIME)  
@Inherited  
public @interface DBTable {   
    public String name() default "";      
}  


@Target(ElementType.TYPE)  
@Retention(RetentionPolicy.RUNTIME)  
public @interface DBTable2 {  
    public String name() default "";      
}  


package com.jyz.study.jdk.reflect;  

import java.util.Arrays;  

import com.jyz.study.jdk.annotation.DBTable;  
import com.jyz.study.jdk.annotation.DBTable2;  

/** 
 * 1.演示从Class对象上获得反射元素Field Method Constructor 
 * 2.演示AnnotatedElement接口的四个方法 
 * @author JoyoungZhang@gmail.com 
 * 
 */  
public class DeclaredOrNot {  

    public static void main(String[] args) {  
        Class<Sub> clazz = Sub.class;

        System.out.println("=================Field===================");                                           
        //public + 继承  
        System.out.println(Arrays.toString(clazz.getFields()));  
        //all + 自身  
        System.out.println(Arrays.toString(clazz.getDeclaredFields()));  

        System.out.println("=================Method====================");  
        //public + 继承  
        System.out.println(Arrays.toString(clazz.getMethods()));  
        //all + 自身  
        System.out.println(Arrays.toString(clazz.getDeclaredMethods()));  

        System.out.println("================Constructor=================");  
        //public + 自身  
        System.out.println(Arrays.toString(clazz.getConstructors()));  
        //all + 自身  
      System.out.println(Arrays.toString(clazz.getDeclaredConstructors()));           

      System.out.println("================AnnotatedElement==============");  
        //注解DBTable2是否存在于元素上  
        System.out.println(clazz.isAnnotationPresent(DBTable2.class));  
        //如果存在该元素的指定类型的注释DBTable2,则返回这些注释,否则返回 null。  
        System.out.println(clazz.getAnnotation(DBTable2.class));  
        //继承  
        System.out.println(Arrays.toString(clazz.getAnnotations()));  
        //自身  
       System.out.println(Arrays.toString(clazz.getDeclaredAnnotations()));  
    }  
}  

@DBTable  
class Super{  
    private int superPrivateF;  
    public int superPublicF;  

    public Super(){  
    }  

    private int superPrivateM(){  
        return 0;  
    }  
    public int superPubliceM(){  
        return 0;  
    }  
}  

@DBTable2  
class Sub extends Super{  
    private int subPrivateF;  
    public int subPublicF;  

    private Sub(){  
    }  
    public Sub(int i){  
    }  

    private int subPrivateM(){  
        return 0;  
    }  
    public int subPubliceM(){  
        return 0;  
    }  
}  



console output:  
============================Field===========================  
[public int com.jyz.study.jdk.reflect.Sub.subPublicF, public int com.jyz.study.jdk.reflect.Super.superPublicF]  
[private int com.jyz.study.jdk.reflect.Sub.subPrivateF, public int com.jyz.study.jdk.reflect.Sub.subPublicF]  
============================Method===========================  
[public int com.jyz.study.jdk.reflect.Sub.subPubliceM(), public int com.jyz.study.jdk.reflect.Super.superPubliceM(), public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException, public final void java.lang.Object.wait() throws java.lang.InterruptedException, public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException, public boolean java.lang.Object.equals(java.lang.Object), public java.lang.String java.lang.Object.toString(), public native int java.lang.Object.hashCode(), public final native java.lang.Class java.lang.Object.getClass(), public final native void java.lang.Object.notify(), public final native void java.lang.Object.notifyAll()]  
[private int com.jyz.study.jdk.reflect.Sub.subPrivateM(), public int com.jyz.study.jdk.reflect.Sub.subPubliceM()]  
============================Constructor===========================  
[public com.jyz.study.jdk.reflect.Sub(int)]  
[private com.jyz.study.jdk.reflect.Sub(), public com.jyz.study.jdk.reflect.Sub(int)]  
============================AnnotatedElement===========================  
true  
@com.jyz.study.jdk.annotation.DBTable2(name=)  
[@com.jyz.study.jdk.annotation.DBTable(name=), @com.jyz.study.jdk.annotation.DBTable2(name=)]  
[@com.jyz.study.jdk.annotation.DBTable2(name=)]  

三.代码说明
1.代码演示了从Class对象上获得反射元素Field Method Constructor时get*和getDeclared*的区别。
public Method[] getMethods()返回某个类的所有公用(public)方法包括其继承类的公用方法,当然也包括它所实现接口的方法。
public Method[] getDeclaredMethods()对象表示的类或接口声明的所有方法,包括公共、保护、默认(包)访问和私有方法,但不包括继承的方法。当然也包括它所实现接口的方法。
2.代码演示了AnnotatedElement接口的四个方法。
1.java.lang.reflect.AnnotatedElement表示可以被注解的元素。它只有四个方法,参考代码DeclaredOrNot.java。
这里写图片描述
2.当我使用clazz.getAnnotations()时,我期望得到控制台打印出来的内容,但实际上却只得到了[@com.jyz.study.jdk.annotation.DBTable2(name=)],后来发现是DBTable里没有声明@Inherited。

`@Inherited` 是一个标准的 Java注解(meta-annotation),用于指示一个注解是否可以被继承。当一个注解被标注为 `@Inherited` 后,它将可以被子类继承。 具体来说,当一个被 `@Inherited` 标注的注解被放置在一个父类上时,它将会被子类继承,并且子类上也会具有该注解。这意味着,如果我们在父类上使用了一个被 `@Inherited` 标注的注解,那么所有继承该父类的子类也将自动具有该注解。 需要注意的是,`@Inherited` 元注解仅对类级别的注解有效,对方法、字段等其他元素的注解无效。 下面是一个示例,展示了如何使用 `@Inherited` 元注解: ```java import java.lang.annotation.*; @Inherited @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface MyAnnotation { // 注解元素 String value(); } ``` 在上面的示例中,我们定义了一个自定义注解 `@MyAnnotation` 并标注了 `@Inherited` 元注解。当我们将 `@MyAnnotation` 注解放置在一个父类上时,该注解将会被子类继承。 ```java @MyAnnotation("Parent") public class ParentClass { // 父类的代码内容 } public class ChildClass extends ParentClass { // 子类的代码内容 } ``` 在上面的示例中,`ChildClass` 继承自 `ParentClass`,由于 `@MyAnnotation` 使用了 `@Inherited` 元注解,所以 `ChildClass` 也会自动具有 `@MyAnnotation("Parent")` 注解。 总结一下,`@Inherited` 是一个元注解,用于指示一个注解是否可以被继承。当一个注解被标注为 `@Inherited` 后,它将可以被子类继承。但需要注意,它仅对类级别的注解有效,对其他元素的注解无效。 希望能够解答你的疑问。如果还有其他问题,请随时提问。谢谢!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值