Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK 与 JRE 与 JVM
- Java - Hello World 程序
- Java - 环境设置
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode 系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期和时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - if-else
- Java - switch
- Java - for 循环
- Java - for-each 循环
- Java - while 循环
- Java - do-while 循环
- Java - break
- Java - continue
面向对象编程
- Java - OOPs 概念
- Java - 对象和类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造函数
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造函数
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误和异常
- Java - 异常
- Java - try-catch 块
- Java - try-with-resources
- Java - 多重 catch 块
- Java - 嵌套 try 块
- Java - finally 块
- Java - throw 异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 加入线程
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络编程
- Java - 网络编程
- Java - Socket 编程
- Java - URL 处理
- Java - URL 类
- Java - URLConnection 类
- Java - HttpURLConnection 类
- Java - Socket 类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级 Java
- Java - 命令行参数
- Java - Lambda 表达式
- Java - 发送邮件
- Java - Applet 基础
- Java - Javadoc 注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像 API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional 类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64 编码解码
- Java - switch 表达式
- Java - Teeing 收集器
- Java - 微基准测试
- Java - 文本块
- Java - 动态 CDS 归档
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 简洁数字格式化
- Java - 垃圾回收
- Java - JIT 编译器
Java 杂项
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - Process API 改进
- Java - Stream API 改进
- Java - 增强 @Deprecated 注解
- Java - CompletableFuture API 改进
- Java - 流
- Java - 日期时间 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java APIs 和框架
Java 类引用
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java 注释
Java 注释
Java 注释 是写在代码中的文本注释,用于解释源代码。注释可以用来解释逻辑或用于文档目的。编译器不会编译注释。在 Java 中,注释与 C 和 C++ 非常相似。
在 Java 中,有三种类型的注释
- 单行注释
- 多行注释
- 文档注释
让我们详细讨论每种类型的注释。
1. 单行注释
单行注释用于在一行上添加注释,可以使用两个正斜杠 (//) 来编写。这些注释是最常用的注释方式。
单行注释是最常用的注释方式,用于解释该行的目的(或添加文本注释)。
语法
考虑以下语法在 Java 中编写单行注释
// comment
示例 1:Java 单行注释
// if divisor is 0 throw an exception if (divisor == 0) { throw new IllegalArgumentException("divisor cannot be zero"); }
示例 2:Java 单行注释
以下代码显示了在简单程序中使用单行注释的情况。我们已向代码行添加注释以解释其用途。
package com.tutorialspoint; public class MyFirstJavaProgram { public static void main(String[] args) { MyFirstJavaProgram program = new MyFirstJavaProgram(); double result = program.divide(100, 10); System.out.println(result); } private double divide(int dividend, int divisor) throws IllegalArgumentException { // if divisor is 0 throw an exception if (divisor == 0) { throw new IllegalArgumentException("divisor cannot be zero"); } return (double) dividend / divisor; // returns the result of the division as double } }
输出
编译并运行 MyFirstJavaProgram。这将产生以下结果:
10.0
2. 多行注释
多行(或多行)注释以正斜杠后跟星号 (/*) 开始,以星号后跟正斜杠 (*/) 结束,它们用于在多行上添加注释。
当我们想要放置一个跨越多行的长注释或注释掉完整的代码时,多行注释非常有用。
语法
考虑以下语法在 Java 中编写多行注释
/* Comment (line 1) Comment (line 2) ... */
示例 1:Java 多行注释
/* This is an example of multi line comment. */ /* if (dividend == 0) { throw new IllegalArgumentException("dividend cannot be zero"); } */
示例 2:Java 多行注释
以下代码显示了在简单程序中使用多行注释的情况。我们使用多行注释注释掉了方法中的额外代码。
package com.tutorialspoint; public class MyFirstJavaProgram { public static void main(String[] args) { MyFirstJavaProgram program = new MyFirstJavaProgram(); double result = program.divide(100, 10); System.out.println(result); } private double divide(int dividend, int divisor) throws IllegalArgumentException { if (divisor == 0) { throw new IllegalArgumentException("divisor cannot be zero"); } /* if (dividend == 0) { throw new IllegalArgumentException("dividend cannot be zero"); } */ return (double) dividend / divisor; } }
输出
编译并运行 MyFirstJavaProgram。这将产生以下结果:
10.0
3. 文档注释
文档注释用于编写源代码的文档。文档注释以正斜杠后跟两个星号 (/**) 开始,以星号后跟反斜杠 (*/) 结束,并且开始和结束之间所有行都必须以星号 (*) 开头。
Javadoc 工具可以理解文档注释,并可用于创建基于 HTML 的文档。
语法
考虑以下语法在 Java 中编写文档注释
/** * line 1 * line 2 ... */
示例 1:Java 文档注释
/** * This is a documentation comment. * This is my first Java program. * This will print 'Hello World' as the output * This is an example of multi-line comments. */ public class MyFirstJavaProgram {}
上述注释风格称为文档注释。Javadoc 工具在为程序代码创建文档时会使用它。我们还可以使用文档注释中的以下注解来提供参数、异常和返回类型的详细信息。
/** * @param dividend * @param divisor * @return quotient * @throws IllegalArgumentException if divisor is zero */ private double divide(int dividend, int divisor) throws IllegalArgumentException { }
示例 2:Java 文档注释
以下代码显示了在简单程序中使用文档注释的情况。我们在类声明上定义了一个注释来提供类的详细信息。对于方法,我们在方法注释部分的文档块中添加了参数、返回值和引发的异常的详细信息。
package com.tutorialspoint; /** * This is a documentation comment. * This is my first Java program. * This is an example of multi-line comments. * We're printing result of divison of two numbers in this program */ public class MyFirstJavaProgram { public static void main(String[] args) { MyFirstJavaProgram program = new MyFirstJavaProgram(); double result = program.divide(100, 10); System.out.println(result); } /** * @param dividend * @param divisor * @return quotient * @throws IllegalArgumentException if divisor is zero */ private double divide(int dividend, int divisor) throws IllegalArgumentException { if (divisor == 0) { throw new IllegalArgumentException("divisor cannot be zero"); } return (double) dividend / divisor; } }
输出
编译并运行 MyFirstJavaProgram。这将产生以下结果:
10.0