java的三种注释方式,java中的几种注释方式?

1、第一步我们首先需要知道java一共有三种注释方式,单行注释//,多行注释 /* */,文档注释/** */,如下图所示:

java的三种注释方式,java中的几种注释方式?

2、第二步打开eclipse,在java代码中使用单行注释//,一般单行注释,注释少量代码或者说明内容,如下图所示:

java的三种注释方式,java中的几种注释方式?

3、第三步java代码中使用多行注释/* */,一般使用多行注释大量的代码或者说明内容,如下图所示:

java的三种注释方式,java中的几种注释方式?

4、第四步使用文档注释/** */,文档注释一般用于对类和方法进行功能说明,如下图所示:

java的三种注释方式,java中的几种注释方式?

5、第五步我们也可以使用快捷键注释代码,选中要注释的代码,如下图所示:

java的三种注释方式,java中的几种注释方式?

6、第六步使用ctrl+?键进行注释代码,再次按ctrl+?键就取消注释,也可以使用ctrl+shift+c对jsp的代码进行注释,如下图所示:

java的三种注释方式,java中的几种注释方式?

"

java的三种注释方式,java中的几种注释方式?

java中的几种注释方式?

首先我得说一下为啥要写注释。

注释仅仅是一段描述某个类或某个方法或某段代码的功能或作用,程序运行不会运行注释部分,并不会影响程序的运行。

既然注释对程序的执行没有任何影响,那么是否应该省略注释呢?

我认为不应该。因为代码未必是一直给一个人看。你终究会离开这个公司,如果不写注释,对于接手你代码的人理解起来就比较费劲。其次,人脑的记忆力是有限的,你不可能记住一个项目的所以实现细节。如果没有注释,当将来的某天在回头来看自己写过的代码,你依然会迷茫一会。所以注释是有必要。

J在ava中有三种注释,分别为:单行注释、多行注释和文档注释。

单行注释以“//”进行注释。通常只对当前行起注释作用。而多行注释则是以“/**/”囊括一段代码,被囊括的代码及被注释。文档注释则是以/***/加在类或方法前面,在生成API文档时辅助生成相关描述性信息。通常情况下,文档注释会配合一些注解来使用。

其中单行注释和多行注释是大多数编程语言都会支持的注释方式,而文档注释则是Java所特有。

总之,不论是哪种编程语言,注释都不可或缺。

"

怎样理解Java的注解并运用注解编程?

一、什么是注解

注解也叫元数据,例如我们常见的@Override和@Deprecated,注解是JDK1.5版本开始引入的一个特性,

用于对代码进行说明,可以对包、类、接口、字段、方法参数、局部变量等进行注解。

一般常用的注解可以分为三类:

1、Java自带的标准注解,包括@Override(标明重写某个方法)、@Deprecated(标明某个类或方法过时)和@SuppressWarnings(标明要忽略的警告),使用这些注解后编译器就会进行检查。

2、类为元注解,元注解是用于定义注解的注解,包括@Retention(标明注解被保留的阶段)、@Target(标明注解使用的范围)、@Inherited(标明注解可继承)、@Documented(标明是否生成javadoc文档)

3、类为自定义注解,可以根据自己的需求定义注解

二、注解的用途

在看注解的用途之前,有必要简单的介绍下XML和注解区别,

注解:是一种分散式的元数据,与源代码紧绑定。

xml:是一种集中式的元数据,与源代码无绑定

当然网上存在各种XML与注解的辩论哪个更好,这里不作评论和介绍,主要介绍一下注解的主要用途:

生成文档,通过代码里标识的元数据生成javadoc文档。

编译检查,通过代码里标识的元数据让编译器在编译期间进行检查验证。

编译时动态处理,编译时通过代码里标识的元数据动态处理,例如动态生成代码。

运行时动态处理,运行时通过代码里标识的元数据动态处理,例如使用反射注入实例

三、注解的实现原理

实现注解三要素:

1、注解声明

2、使用注解的元素

3、操作注解使其起作用(注解处理器)

注解声明

首先我们让看一下java中的元注解(也就是上面提到的注解的注解),总共有4个如下:

@Target,@Retention,@Documented,@Inherited这4个元注解都是在jdk的java.lang.annotation包下面,

@Target:Target说明的是Annotation所修饰的对象范围。@Retention:

定义了该Annotation被保留的时间长短:某些Annotation仅出现在源代码中,而被编译器丢弃;而另一些却被编译在class文件中;编译在class文件中的Annotation可能会被虚拟机忽略,

而另一些在class被装载时将被读取(请注意并不影响class的执行,因为Annotation与class在使用上是被分离的)。

使用这个元注解可以对 Annotation的“生命周期”限制。@Documented:@Documented用于描述其它类型的annotation应该被作为被标注的程序成员的公共API,因此可以被例如javadoc此类的工具文档化。Documented是一个标记注解,没有成员

@Inherited:@Inherited 元注解是一个标记注解,@Inherited阐述了某个被标注的类型是被继承的。如果一个使用了@Inherited修饰的annotation类型被用于一个class,

则这个annotation将被用于该class的子类。

注意:@Inherited annotation类型是被标注过的class的子类所继承。类并不从它所实现的接口继承annotation,方法并不从它所重载的方法继承annotation。

当@Inherited annotation类型标注的annotation的Retention是RetentionPolicy.RUNTIME,则反射API增强了这种继承性。如果我们使用java.lang.reflect去查询一个@Inherited annotation类型的annotation时,

反射代码检查将展开工作:检查class和其父类,直到发现指定的annotation类型被发现,或者到达类继承结构的顶层。

java.lang.reflect.AnnotatedElement 接口是所有程序元素(Class、Method和Constructor)的父接口,所以程序通过反射获取了某个类的AnnotatedElement对象之后,程序就可以调用该对象的如下四个个方法来访问Annotation信息:

  方法1: T getAnnotation(Class annotationClass): 返回改程序元素上存在的、指定类型的注解,如果该类型注解不存在,则返回null。

  方法2:Annotation[] getAnnotations():返回该程序元素上存在的所有注解。

  方法3:boolean is AnnotationPresent(Class annotationClass):判断该程序元素上是否

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

发表评论

登录后才能评论