【JavaSE专栏9】Java 注释知多少

news2024/10/6 18:24:27

作者主页:Designer 小郑
作者简介:Java全栈软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue、SpringBoot和微信小程序)、系统定制、远程技术指导。CSDN学院、蓝桥云课认证讲师,全栈领域优质创作者。热爱技术、专注业务、开放合作、乐于分享,期待你我共同成长!
主打方向:Vue、SpringBoot、微信小程序

目录

    • 一、一般注释
      • 1.1 块注释
      • 1.2 单行注释
      • 1.3 尾端注释
    • 二、文档注释
    • 三、注释使用规范
    • 四、课时小结

在 Java 中存在两类注释,即一般注释和文档注释,在本文中对齐阐述。

注释是指解释字句的文字,也指用文字解释字句。可以是文字符号图片等多种形式。注释,是对书籍或文章的语汇、内容、背景、引文作介绍、评议的文字。

一般注释是同学们在 C 语言中见过的,使用 /**/// 字符界定的注释。

文档注释是 Java 特有的,文档注释可通过 JavaDoc 工具转换为 HTML 文件。

一般注释用于注释代码或者实现细节。文档注释从实现自由的角度描述代码的规范,手上没有源码的开发者也应可以读懂文档注释。

注释应该仅包含与阅读和理解程序有关的信息

在实战开发中,对设计决策中重要的,或者不是显而易见的地方进行说明是可以的,但应避免提供代码中已经明确表达出来的重复信息,多余的注释很容易过时。

提示:频繁的注释是质量较低的代码之一。当你在开发中频繁觉得需要添加注释时,说明你的业务逻辑不太清晰,此时建议重写相关代码。

在这里插入图片描述


一、一般注释

Java 程序中有 4 种实现注释的风格,如下:

  1. 单行
  2. 尾端
  3. 行末

1.1 块注释

块注释通常用于提供对文件、方法、数据结构或算法的阐述

块注释被置于每个文件的开始处以及每个方法之前,也可以用于其他地方,比如方法的内部。

在功能和方法内部的块注释应该有相对于的缩进,保持代码整洁,如下所示。

public class Main {

    public static void main(String[] args) {

        /**
         * 这是块注释,需要有缩进!
         */
        System.out.println("aa" + "bb");
    }
}

1.2 单行注释

单行注释可以显示在一行之内,并和其后的代码具有相同的缩进。

提示:如果单行注释不能在一行中写完,则建议使用块注释。

在单行注释之前应该有一个空行,使用单头注释 // ,即在代码行的开头进行注释。

单行注释的样例如下所示。

public class Main {

    public static void main(String[] args) {

        // System.out.println("aa" + "bb");
    }
}

1.3 尾端注释

尾端注释用于极短的注释需求,尾端注释和所要描述的代码块在同一行,但其中要有足够的空格来分开,另外也要注意缩进问题。

尾端注释的样例如下所示。

public class Main {

    private static final int MAX_SIZE = 10;
    public static void main(String[] args) {

        System.out.println("aa" + "bb");    /* 尾端注释 A  */
        System.out.println("cc" + "dd");    /* 尾端注释 B  */
    }
}

二、文档注释

文档注释用来描述 Java 的类、接口、构造器、方法、字段

每个文档注释都会在 /***/ 之间,一个文档注释对应一个类、接口或成员,一般用来对类、接口、成员方法、成员变量、静态字段、常量进行说明。

JavaDoc 工具可以用文档注释自动 HTML 格式的代码文档。

文档注释经常采用一些标签来进行特定的用途或超链接,常用的注释标签如下:

  • @author:对类的说明,解释开发该类的作者。
  • @version:对类的说明,解释该类的版本。
  • @see:对类、属性、方法的说明,解释相关主题。
  • @param:对方法的说明,解释方法中的某个参数含义。
  • @exception:对方法的说明,解释方法可能抛出的异常含义。
  • @return:对方法的说明,解释方法返回值的含义。

文档注释样例如下所示:

/**
 * @author Designer 小郑
 * @See https://blog.csdn.net/qq_41464123
 */
public class Main {

    private static final int MAX_SIZE = 10;
    public static void main(String[] args) {

        System.out.println("aa" + "bb");
    }
}

javadoc 和 javac、java 一样,是 jdk 的一个工具,只需输入 javac 类目录即可完成 HTML 文件导出。

javac C:\java\git\test\test\Main.java

在这里插入图片描述


三、注释使用规范

同学们在使用 Java 注释时,需要注意以下规范:

  1. 注释应该使代码更为清晰易懂,而不是记日记,也不能描绘思想感情。
  2. 注释要当简单明了,能用一句话就不用两句。如果注释太复杂,请检查代码逻辑是否有问题。
  3. 注释既要阐述相应代码能做什么,还要解释为什么要这么做和开发约束。
  4. 一般的增删改查方法,以及 getset 方法不需要做注释。
  5. 注释不能嵌套,否则编译不能通过。

四、课时小结

在本课时中,首先讲解了 Java 的注释概念,接着学习了一般注释和文档注释的用法,其中一般注释可分为块注释、单行注释和尾端注释。在下一节课时中,将讲解 Java 的顺序结构语法。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/179608.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

斐波那契数列的--------5种算法(又称“兔子数列”)

斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:…

决策树-剪枝处理

前言:理解《机器学习》P79-83中的决策树剪枝示例。 决策树生成 原始数据集如下所示,前10行为训练集,后7行为验证集,由此数据集可生成如下所示的决策树。 下面解释未进行剪枝操作的决策树为何如上图所示。 不对解释每个结点和分支…

WPF-3D图形

WPF-3D图形 WPF的3D功能可以在不编写任何c#代码的情况下进行绘制,只需要使用xaml即可完成3D图形的渲染。本文主要讲述了WPF-3D中的关键概念, 以及常用到的命中测试、2d控件如何在3D对象中进行渲染,除此之外,还演示了如何导入外部…

InstanceNorm LayerNorm

InstanceNorm && LayerNorm author: SUFEHeisenberg date: 2023/01/26 先说结论: 将Transformer类比于RNN:一个token就是一层layer,对一整句不如token有意义原生Bert代码或huggingface中用的都是InstanceNorm instead of LayerNorm&#xff…

【AAAI2023】Head-Free Lightweight Semantic Segmentation with Linear Transformer

论文:【AAAI2023】Head-Free Lightweight Semantic Segmentation with Linear Transformer 代码:https://github.com/dongbo811/AFFormer 这是来自阿里巴巴的工作,作者构建了一个轻量级的Transformer网络用于语义分割,主要有两点…

发现下属的学历造假,但是他的工作能力又很强,该开除他吗?

在职场上混,学历是敲门砖还是定音锤呢?一位网友问:发现下属的学历造假,但是他的工作能力又很强,该开除他吗?有人觉得一定要开除,这就是钻空子,受影响最大的人不是他,而是那些真才实…

上采样与下采样

数据分析中的上采样和下采样 背景: 在分类问题中,由于各种原因,我们所获取到的数据集很容易出现正负样本的不平衡,或者某些数据特别多,有些数据则特别少,在这样的数据集中,进行训练&#xff0c…

OpenCV直方图Java 演示程序

直方图Java 演示程序以下文件编码为utf-8 为佳。代码文件名:OpenCvMain.javapackage org.opencv;import java.net.URL;import java.util.LinkedList;import java.util.List;import org.opencv.core.Core;import org.opencv.core.CvType;import org.opencv.core.Mat;…

Linux常用命令——setpci命令

在线Linux命令查询工具(http://www.lzltool.com/LinuxCommand) setpci 查询和配置PCI设备的使用工具 补充说明 setpci命令是一个查询和配置PCI设备的使用工具。 语法 setpci(选项)(参数)选项 -v:显示指令执行的细节信息; -f:当没有任何…

Opencv形态学操作——腐蚀、膨胀、梯度、开运算、闭运算、礼帽、黑帽(附案例详细讲解及可执行代码)

Opencv形态学操作 腐蚀膨胀梯度开运算闭运算礼帽黑帽总结腐蚀 在地理或者化学中,我们学习过腐蚀,是指在某种 作用下产生损耗与破坏的过程。你也可以理解为减肥。在Opencv中,腐蚀操作可以使白色轮廓变小,也就是说可以去除一些白色的噪声。 如果你接触过卷积核的话,腐蚀就更…

【JavaSE专栏8】运算符、表达式和语句

作者主页:Designer 小郑 作者简介:Java全栈软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue、SpringBoot和微信小程序)、系统定制、远程技术指导。CSDN学院、蓝桥云…

盖子的c++小课堂——第十三讲:二维数组

前言 过了几天了,终于有时间更新了,有个通知,以后我不用颜色区分了,不然换了背景看不见,理解一下,蟹蟹~~ 举例 作者:一下是某次奥运会的奖牌榜,你知道如何储存奖牌榜吗~~ 粉丝&am…

机器学习中软投票和硬投票的不同含义和理解

设置一个场景,比如对于今天音乐会韩红会出现的概率三个人三个观点 A:韩红出现的概率为47% B:韩红出现的概率为57% C:韩红出现的概率为97% 软投票:软投票会认为韩红出现的概率为1/3*(47%57%97%)67% 硬投票:…

“子序列问题”系列总结,一文读懂(Java实现)

目录 前言 一、最长递增子序列 1.1、dp定义 1.2、递推公式 1.3、初始化 1.4、注意 1.5、解题代码 二、最长连续递增序列 2.1、分析 2.2、解题代码 三、最长重复子数组 3.1、dp定义 3.2、递推公式 3.3、初始化 3.4、解题代码 四、最长公共子序列 4.1、分析 4.2…

Opencv项目实战:20 单手识别数字0到5

目录 0、项目介绍 1、效果展示 2、项目搭建 3、项目代码展示 HandTrackingModule.py Figures_counter.py 4、项目资源 5、项目总结 0、项目介绍 今天要做的是单手识别数字0到5,通过在窗口展示,实时的展示相应的图片以及文字。 在网上找了很久的…

硬核来袭!!!一篇文章教你入门Python爬虫网页解析神器——BeautifulSoup详细讲解

文章目录一、BeautifulSoup介绍二、安装三、bs4数据解析的原理四、bs4 常用的方法和属性1、BeautifulSoup构建1.1 通过字符串构建1.2 从文件加载2、BeautifulSoup四种对象2.1 Tag对象2.2 NavigableString对象2.3 BeautifulSoup对象2.4 Comment对象五、contents、children与desc…

springboot自定义拦截器的简单使用和一个小例子

springboot自定义拦截器的使用1. 自定义拦截器2. 拦截器登录验证的小demo2.1 配置pom.xml2.2 创建User的bean组件2.3 创建需要的表单页面以及登录成功的页面2.4 编写controller映射关系2.5 自定义拦截器类,实现intercepetor接口2.6注册添加拦截器,自定义…

【SpringCloud】Nacos集群搭建

集群结构图官方给出的Nacos集群图如下:其中包含3个nacos节点,然后一个负载均衡器代理3个Nacos。这里负载均衡器可以使用nginx。我们接下来要尝试 Nacos集群搭建,效果图如下所示:三个nacos节点的地址:节点ipportnacos1l…

二、Java框架之Spring注解开发

文章目录1. IOC/DI注解开发1.1 Component注解ComponentController Service Repository1.2 纯注解开发模式1.3 注解开发bean管理ScopePostConstruct PreDestroy1.4 注解开发依赖注入Autowired QualifierValuePropertySource1.5 第三方bean管理Beanimport(多个Config类…

Redisson 完成分布式锁

1、简介 Redisson 是架设在 Redis 基础上的一个 Java 驻内存数据网格(In-Memory Data Grid)。充分 的利用了 Redis 键值数据库提供的一系列优势,基于 Java 实用工具包中常用接口,为使用者 提供了一系列具有分布式特性的常用工具类…