@interface使用详解(转载)

导读:本篇文章讲解 @interface使用详解(转载),希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

另一篇文章详细总结了接口相关的内容:注解详解

首先,@interface不是接口是注解类,在jdk1.5之后加入的功能,使用@interface自定义注解时,自动继承了java.lang.annotation.Annotation接口,由编译程序自动完成其他细节,我们通过反编译可以看到,源代码如下:

//保留的环境
@Retention(RUNTIME)
//注释起作用的位置,此处表示它只能给类、接口、枚举注解
@Target(TYPE)
public @interface Test {
  
  public int id() default -1;
 
  public String msg() default "Hi";
}

编译之后用javap -p Test.class得到如下结果:

在这里插入图片描述

在定义注解时,不能继承其他的注解或接口。@interface用来声明一个注解,其中的每一个方法实际上是声明了一个配置参数。方法的名称就是参数的名称,返回值类型就是参数的类型(返回值类型只能是基本类型、Class、String、enum)。可以通过default来声明参数的默认值。

在Java API文档中特意强调了如下内容:

Annotation是所有注释类型的公共扩展接口。注意,手动扩展这个接口并不定义注释类型。还要注意,这个接口本身并不定义注释类型。注释类型的更多信息可以在Java™语言规范的9.6节。

@interface可以实现三种功能:

(1)声明类:Class
(2)声明类别:Category
(3)声明扩展:Extension

1.声明类:

这个就比较常用:

@interface SomeClass : NSObject {
}

2.声明类别:

(1)类别能在不更改原来的类代码的情况下,为类增加方法或者重写类的方法。
(2)类别只能添加或者重写方法,但是不能添加变量。
(3)有网友说将类别名设定为“Private”,就能使类别中增加的方法成为私有方法,这个是不成立的(经过实际代码验证)。
(4)如果是重写类的已经存在的方法,则此重写的方法会在整个运行环境中生效,而且不需要在用到的地方导入实现类;
如果是为类增加新的方法,则需要在用的地方导入。
(5)代码:
@interface ClassName(类别名){
}

3.声明扩展:

(1)扩展和类别语法上的的区别很简单,就是类别名省略,只保留括号。
(2)扩展只是增加原来类的方法和变量的声明,而不包含实现,所以,扩展没有独立的实现(@implementation),而是和原来的类共享一个实现。
(3)扩展不仅能在原来类的基础上增加方法,也能增加变量。
(4)如果将扩展写到实现文件中,则增加的变量和方法就是私有变量和私有方法。
(5)代码:
@interface ClassName(){
}
————————————————
版权声明:本文为CSDN博主「little-motor」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_39385118/article/details/80599837

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/115447.html

(0)
Java光头强的头像Java光头强

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!