[Java 基礎]注釋

注釋在編程中扮演著非常重要的角色,它們是寫給人類閱讀的,而不是給計算機執行的。良好的注釋可以極大地提高代碼的可讀性和可維護性。

為什么需要注釋?

  1. 提高可讀性: 注釋可以解釋代碼的功能、實現思路、特殊處理等,幫助其他開發者(或者未來的你)更容易理解代碼的意圖
  2. 方便維護: 當代碼需要修改或維護時,清晰的注釋能夠幫助開發者快速定位需要修改的部分,并理解修改可能帶來的影響
  3. 生成文檔: 特定格式的注釋(Javadoc)可以被工具自動提取,生成專業的 API 文檔
  4. 調試代碼: 在調試過程中,可以使用注釋臨時禁用某些代碼塊,方便定位問題
  5. 作為備忘: 開發者可以在代碼中添加一些臨時的想法或注意事項

Java 支持三種類型的注釋:

1. 單行注釋 (Single-line Comments)

以雙斜線 // 開頭,直到行尾的內容都被視為注釋。單行注釋通常用于解釋代碼中的某一行或一小段代碼的功能。

// 這是一個單行注釋
int age = 30; // 聲明一個整型變量 age 并賦值為 30

2. 多行注釋 (Multi-line Comments)

以 /* 開頭,以 / 結尾。/ 和 */ 之間的所有內容都被視為注釋,可以跨越多行。多行注釋通常用于解釋一段較長的代碼塊、一個方法或一個類的整體功能。

/** 這是一個多行注釋。* 它可以跨越多行,* 用于解釋一段代碼的功能或者提供更詳細的說明。*/
public class MyClass {// ... 類的內容 ...
}

:::color3
多行注釋不能嵌套使用。也就是說,在一個多行注釋內部不能再包含另一個 /* ... */ 注釋。

:::

3. 文檔注釋 (Documentation Comments) - Javadoc

文檔注釋是一種特殊的多行注釋,以 /** 開頭,以 */ 結尾。文檔注釋主要用于為類、接口、方法、構造器、字段和枚舉常量生成 API 文檔。Javadoc 工具可以解析這些注釋,并生成 HTML 格式的文檔。

文檔注釋的內容可以包含特殊的標簽(以 @ 開頭),用于描述不同的方面,例如參數、返回值、異常、作者、版本等。

/*** 這是一個表示一個簡單計算器的類。* 它提供了加法和減法運算。** @author John Doe* @version 1.0* @since 1.0*/
public class Calculator {/*** 將兩個整數相加。** @param a 第一個整數* @param b 第二個整數* @return 兩個整數的和* @throws ArithmeticException 如果發生算術錯誤(雖然在這個例子中不會發生)*/public int add(int a, int b) {return a + b;}/*** 從第一個整數中減去第二個整數。** @param a 被減數* @param b 減數* @return 兩個整數的差*/public int subtract(int a, int b) {return a - b;}
}

常用的 Javadoc 標簽包括:

  • @author:標識作者。
  • @version:標識版本號。
  • @param:描述方法的參數,后面跟著參數名和描述。
  • @return:描述方法的返回值。
  • @throws@exception:描述方法可能拋出的異常,后面跟著異常類名和描述。
  • @since:標識從哪個版本開始引入。
  • @deprecated:標識該元素已過時,并說明替代方案。

因為 IDEA 創建的 Java 類是沒有類注釋的,所以,我一般習慣在 IDEA 中創建一個類文檔注釋模板,讓后配置對應的觸發字符,輸入觸發字符就能快速的生成類的文檔注釋:

/***** @author jxd* {@code @date} $DATETIME$*/

date("yyyy/MM/dd HH:mm")

在已創建的類上使用 *head ,然后按下 Enter 鍵,就會自動生成文檔注釋模板。

編寫良好注釋的建議

  1. 保持注釋的簡潔和清晰: 注釋應該易于理解,避免使用過于晦澀的術語或過長的段落。
  2. 注釋應該準確地反映代碼的功能: 當代碼修改時,務必更新相關的注釋,確保它們與代碼保持一致。
  3. 解釋代碼的意圖,而不是僅僅描述代碼做了什么: 好的注釋應該解釋 為什么 這段代碼是這樣寫的,而不是簡單地重復代碼本身。
  4. 為重要的代碼塊、方法和類添加注釋: 特別是那些邏輯復雜、容易產生誤解或者對外提供的 API。
  5. 使用文檔注釋 (Javadoc) 為公共 API 生成文檔: 這有助于其他開發者了解如何使用你的代碼。
  6. 避免過度注釋: 對于顯而易見的代碼,不一定需要添加注釋。過多的注釋反而會使代碼顯得冗余。
  7. 使用統一的注釋風格: 保持整個項目注釋風格的一致性,提高代碼的整體可讀性。
  8. 及時刪除不再需要的注釋: 例如,一些臨時的調試代碼注釋在問題解決后應該被刪除。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/83611.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/83611.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/83611.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

TortoiseSVN賬號切換

SVN登錄配置及賬號切換 本文主要為了解答svn客戶端如何進行賬號登錄及切換不同權限賬號的方式。 一、環境準備與客戶端安裝 安裝TortoiseSVN客戶端 ??下載地址??:TortoiseSVN官網 ??安裝步驟??: 雙擊安裝包,按向導完成安裝后&#x…

5分鐘了解JVM運行時數據區域

點擊藍字,關注我們 在 Java 程序運行期間,JVM 會劃分出幾塊重要的內存區域,用來支撐類加載、方法調用、對象分配、線程執行等一切運行時行為。 這些區域構成了 JVM 的“運行時數據區”。 一、運行時數據區域概覽圖 二、Java 堆(H…

深入理解CSS浮動:從基礎原理到實際應用

深入理解CSS浮動:從基礎原理到實際應用 引言 在網頁設計中,CSS浮動(float)是一個歷史悠久卻又至關重要的概念。雖然現代布局技術如Flexbox和Grid逐漸流行,但浮動仍然在許多場景中發揮著重要作用。本文將帶你深入理解…

Spring Bean 為何“難產”?攻克構造器注入的依賴與歧義

本文已收錄在Github,關注我,緊跟本系列專欄文章,咱們下篇再續! 🚀 魔都架構師 | 全網30W技術追隨者🔧 大廠分布式系統/數據中臺實戰專家🏆 主導交易系統百萬級流量調優 & 車聯網平臺架構&a…

華為云Flexus+DeepSeek征文|實戰體驗云服務器單機部署和CCE高可用的架構AI賦能

前引:“在數字化浪潮洶涌澎湃的今天,企業對云計算服務的需求已從基礎架構支撐,逐步轉向更深層次的AI賦能與業務創新驅動。面對復雜多變的市場環境,選擇一個強大、可靠且具備前瞻性的云服務伙伴,無疑是企業實現高速增長…

雷卯針對易百納G610Q-IPC-38E 模組防雷防靜電方案

一、應用場景 1、智能監控 2、智能家居 3、工業自動化 4、機器人 5、智能交通 6、醫療影像 7、教育科研 二、 功能概述 1 HI3516CV610(ARM Cortex-A7 MP2) 2 AI算力 1Tops 3 模組集成 4M30FPS Sensor,支持最高 6M30fps 的 ISP 圖像…

生成對抗網絡(GAN)基礎原理深度解析:從直觀理解到形式化表達

摘要 本文詳細解析 生成對抗網絡(GAN) 的 核心原理,從通俗類比入手,結合印假鈔與警察博弈的案例闡述生成器 與 判別器 的對抗機制;通過模型結構示意圖,解析 噪聲采樣、樣本生成 及判別流程;基于…

OptiStruct結構分析與工程應用:無限元法介紹

13.3 無限元方法 本節將詳細闡述如何利用無限元方法求解外聲場分析,具體包括無限元方法基本理論,無限單元介紹、無限元分析建模指南及檢查,最后以一個實例講解整個分析設置過程。 13.3.1 無限元分析基礎理論 無限元求解外聲場的基本原理如…

判斷:有那種使用了局部變量的遞歸過程在轉換成非遞歸過程時才必須使用棧

這道題的關鍵在于理解遞歸轉非遞歸與 “是否用棧” 的本質邏輯,和 “局部變量” 無關,核心看遞歸的調用上下文是否需要保存。 一、遞歸的本質:依賴 “調用棧” 遞歸函數執行時,系統會用調用棧保存: 每層遞歸的參數、…

leetcode1443. 收集樹上所有蘋果的最少時間-medium

1 題目:收集樹上所有蘋果的最少時間 官方標定難度:中 給你一棵有 n 個節點的無向樹,節點編號為 0 到 n-1 ,它們中有一些節點有蘋果。通過樹上的一條邊,需要花費 1 秒鐘。你從 節點 0 出發,請你返回最少需…

MySQL 索引底層原理剖析:B+ 樹結構、索引創建維護與性能優化策略全解讀

引言 在 MySQL 數據庫的世界里,索引是提升查詢性能的關鍵利器。然而,很多開發者雖然知道索引的重要性,但對于索引背后的底層原理卻知之甚少。本文將深入 MySQL 索引的底層實現,剖析 B 樹的結構特點,以及如何利用這些知…

【Delphi】實現在多顯示器時指定程序運行在某個顯示器上

在多顯示器時代,經常會出現期望將程序運行在某個指定的顯示器上,特別是在調試程序的時候,期望切換分辨率,單步調試時,此時容易導致互相卡住,非常不方便,但是通過指定程序運行在不同的顯示器上就…

不動產登記區塊鏈系統(Vue3 + Go + Gin + Hyperledger Fabric)

好久沒有介紹過新項目的制作了,之前做的一直都是Fisco Bcos的項目,沒有介紹過Hyperledger Fabric的項目,這次來給大家分享下。 系統概述 不動產登記與交易平臺是一個基于Hyperledger Fabric的綜合性管理系統,旨在實現不動產登記…

論文閱讀筆記——Large Language Models Are Zero-Shot Fuzzers

TitanFuzz 論文 深度學習庫(TensorFlow 和 Pytorch)中的 bug 對下游任務系統是重要的,保障安全性和有效性。在深度學習(DL)庫的模糊測試領域,直接生成滿足輸入語言(例如 Python )語法/語義和張量計算的DL A…

cocos3.X的oops框架oops-plugin-excel-to-json改進兼容多表單導出功能

在使用oops框架的過程中,它的導出數據并生成數據結構的插件oops-plugin-excel-to-json有些小的坑點,為滿足我個人習慣,對此部分進行了一個小的修改,有需要的拿去用,記錄下供大家參考; 一、配置:…

解決IDE編譯JAVA項目時出現的OOM異常問題

出現的異常如圖: java.lang.0utOfMemoryError:Java heap space 解決方案: 文件 --> 設置 搜索 編譯器(就點擊編譯器這行),找到構建進程,共享堆大小,設置大一些,例如 2048 MB。 …

【Linux內核】設備模型之udev技術詳解

目錄 1. udev技術概述 2. 技術層次分析 2.1 內核層交互 2.2 規則引擎層 2.3 用戶空間實現 3. 關鍵技術要點 3.1 動態設備節點管理 3.2 熱插拔處理 3.3 模塊化規則系統 3.3.1. 變量替換功能 3.3.2. 條件判斷能力 3.3.3. 實現機制 3.3.4 應用場景 3.3.5 擴展能力 4…

群論在現代密碼學中的應用探索與實踐 —— 從理論到C語言實現

1. 引言:數字時代的信息安全挑戰 隨著互聯網和數字技術的快速發展,信息安全問題變得日益嚴峻。無論是個人隱私保護,還是企業數據安全,乃至國家安全,都依賴于有效的加密技術保障信息的機密性和完整性。網絡攻擊、數據泄…

前端開發處理‘流式數據’與‘非流式數據’,在接收完整與非完整性數據時應該如何渲染和使用

在前端開發中,處理 非流式數據 和 流式數據 的方式不同。根據是否完整接收數據、是否實時渲染的需求,可以分為以下四種典型場景: 一、四類常見場景總結 類型數據完整性是否實時渲染適用技術/方法A完整數據(一次性返回&#xff09…

thymeleaf直接調用Spring Bean中定義的方法

thymeleaf中可以使用表達式工具對象&#xff0c;通過符號直接調Spring Bean中定義的方法 Spring Bean Component public class InvokeMethodBean {public String fun() { return "fun";} }thymeleaf中調用 <div th:text"${invokeMethodBean.fun()}"&…