大家好,今天小编关注到一个比较有意思的话题,就是关于java语言写注释的问题,于是小编就整理了3个相关介绍Java语言写注释的解答,让我们一起看看吧。
使用eclipse如何自动生成注释?
windows–>preference
JAVA–>Code Style–>Code Templates
code–>new J***a files
编辑它
123456789
${filecomment}${package_declaration}/*** @author 作者 E-mail:* @version 创建时间:${date} ${time}* 类说明*/${typecomment}${type_declaration}
方法二:
通过菜单 Window->Preference 打开参数设置面板,然后选择:
J***a -> Code Style -> Code Templates
J***a的注解是什么原理?
首先,从一个简单的注解开始,@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface Test {
String value() default "";
}
使用j***ap -verbose命令查看这个注解的class文件,发现这个注解被编译成了接口,并且继承了j***a.lang.annotation.Annotation接口,接口是不能直接实例化使用的,当在代码中使用这个注解,并使用getAnnotation方法获取注解信息时,JVM通过动态代理的方式生成一个实现了Test接口的代理对象实例,然后对该实例的属性赋值,value值就存在这个代理对象实例中。
如果顺着getAnnotation方法继续跟踪源代码,会发现创建代理对象是在AnnotationParser.j***a中实现的,这个类中有一个annotationForMap方法。在annotationForMap方法内部使用Proxy.newProxyInstance方法在运行时动态创建代理,AnnotationInvocationHandler实现了InvocationHandler接口,当调用代理对象的value()方法获取注解的value值,就会进入AnnotationInvocationHandler类中的invoke方法,深入invoke方***发现,获取value值最终是从AnnotationInvocationHandler类的memberValues属性中获取的,memberValues是一个Map类型,key是注解的属性名,这里就是“value”,value是使用注解时设置的值。
因为回答中不能插入源码做讲解***,更多详细内容可以关注『J***a实战技术』主页的原创文章《J***a注解是如何玩转的,面试官和我聊了半个小时》。
怎么对类名进行文档注释?
对类名进行文档注释可以使用J***aDoc风格的注释,格式如下:
```j***a
/**
* <p>
* 详细描述类的功能和特性
* </p>
*
* @param <T> 泛型参数说明
到此,以上就是小编对于J***A语言写注释的问题就介绍到这了,希望介绍关于J***A语言写注释的3点解答对大家有用。