关于元注解@Inherited的探究

学习中发现采用本文探讨的元注解注解的自定义注解,位于接口中或父类里的方法上的注解不是都能被继承下来的。

我做的试验时:(只列举父类中的方法上的自定义注解无法被继承这种情况,稍加改动即可做关于接口中的方法无法被继承下来的试验。)

这是自定义注解类

package cn.it.test;

import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Inherited//希望子类可以继承
public @interface myannotation{
	public String value();
}


这是抽象父类:

package cn.itcast.test;


public interface AbstructClas {
	//对于注解属性名为value的情况,可以不写属性名
	@myannotation("check")
	public void test();
}


子类:

package cn.itcast.test;

import org.junit.Test;

public class ExtendClas implements AbstructClas {
	@Test
	@Override
	public void test() {
		System.out.println("here is myannotation test!");
		try {
			
				try {
					if(this.getClass().getMethod("test",null).isAnnotationPresent(myannotation.class)){
						System.out.println("这里有指定的注解!");
					}else{
						System.out.println("没有指定的注解!");
					}
				} catch (NoSuchMethodException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} 
		
	}

}

运行结果:

没有指定的注解!


但是如果注解的作用对象是类就可以被继承下来,即@Inherited(ElementType.TYPE)
对上面案例修改,1.在myannotation注解类中将@Inherited(ElementType.METHOD)修改为@Inherited(ElementType.TYPE)  2.在抽象父类中将注解的位置改加到类上面  3.在子类中将检测是否有指定注解的语句改为:this.getClass().isAnnotationPresent(myannotation.class) 


另外还试验了接口上的注解能否被实现它的类继承下来,结果发现无法继承。


这里有篇文章:(CSDN网友ldh911告知)http://xiangdefei.iteye.com/blog/1044199和我探讨的相关。写到这里,我大概看了一些作者的结论,启发我考虑到方法是否被重写这一因素。

我测了一下,不改动接口中的方法,结果接口中方法上的注解也无法被继承。如果是类中的方法上的注解,在不被子类重写的情况下,果真可以被继承下来,这一点和这篇文章中结论一致。


结论:

对于使用元注解@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` 后,它将可以被子类继承。但需要注意,它仅对类级别的注解有效,对其他素的注解无效。 希望能够解答你的疑问。如果还有其他问题,请随时提问。谢谢!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值