java的注解是什么原理?
首先,从一个简单的注解开始,@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface Test {
String value() default "";
}
使用Javap -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***a中的几种注释方式?
1、第一步我们首先需要知道j***a一共有三种注释方式,单行注释//,多行注释 /* */,文档注释/** */,如下图所示:
2、第二步打开eclipse,在j***a代码中使用单行注释//,一般单行注释,注释少量代码或者说明内容,如下图所示:
3、第三步j***a代码中使用多行注释/* */,一般使用多行注释大量的代码或者说明内容,如下图所示:
4、第四步使用文档注释/** */,文档注释一般用于对类和方法进行功能说明,如下图所示:
5、第五步我们也可以使用快捷键注释代码,选中要注释的代码,如下图所示:
6、第六步使用ctrl+?键进行注释代码,再次按ctrl+?键就取消注释,也可以使用ctrl+shift+c对jsp的代码进行注释,如下图所示:
使用eclipse如何自动生成注释?
方法一:Eclipse中设置在创建新类时自动生成注释
windows–>preference
J***a–>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