您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關如何在IDEA中快速刪除Java代碼中的注釋,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
JavaParser解析源碼并得到AST。
識別出注釋類型的節點并將其刪掉。
將AST中剩余的節點按一定規則打印出來。
在實踐之前,我們先要了解Java中的幾種注釋類型:
LineComment 單行注釋。
BlockComent 塊注釋。
JavadocComment Java文檔注釋。
下面舉個簡單例子,說明三種注釋的區別:
import java.util.ArrayList; import java.util.stream.Collectors; /** * @author xiaoxi666 * @date 2021-02-15 17:13 * 我是 Javadoc 注釋 */ public class Input { /** * 我是 Javadoc 注釋 * * @param param1 * @param param2 */ public static void someMethod(String param1, // 我是單行注釋 String param2 // 我是單行注釋 String param3, /* 我是塊注釋 String param4, String param5, String param6 */ /* 我是塊注釋 String param4 */) { // 我是單行注釋 int a = 1; /* 我是塊注釋,注意我和Javadoc注釋的區別,我只有一個星號 */ int b = 2; /* * 我是塊注釋 */ int c = 3; String s1 = "// 我是字符串中的內容,不是注釋"; String s2 = "/* 我是字符串中的內容,不是注釋 */"; String s3 = "/** 我是字符串中的內容,不是注釋 */"; } }
下面我們實踐一下,看看怎么移除源碼中的注釋。
我這里使用maven管理項目,首先引入JavaParser依賴:
<dependencies> <dependency> <groupId>com.github.javaparser</groupId> <artifactId>javaparser-symbol-solver-core</artifactId> <version>3.18.0</version> </dependency> </dependencies>
然后編寫核心代碼:
package core;import com.github.javaparser.JavaParser; import com.github.javaparser.ParseResult; import com.github.javaparser.ParserConfiguration; import com.github.javaparser.ast.CompilationUnit; import com.github.javaparser.ast.Node; import com.github.javaparser.ast.comments.BlockComment; import com.github.javaparser.ast.comments.Comment; import com.github.javaparser.ast.comments.LineComment; import com.github.javaparser.printer.lexicalpreservation.LexicalPreservingPrinter; import java.util.List; import java.util.Optional; import java.util.stream.Collectors; /** * @author xiaoxi666 * @date 2021-02-15 20:09 * 幾個注釋的概念: * LineComment * BlockComment * JavadocComment */ public final class CommentsRemover { private CommentsRemover() {} public static String doAction(String content) { JavaParser javaParser = createJavaParser(); ParseResult<CompilationUnit> result = javaParser.parse(content); Optional<CompilationUnit> optionalCompilationUnit = result.getResult(); if (!optionalCompilationUnit.isPresent()) { return ""; } CompilationUnit compilationUnit = optionalCompilationUnit.get(); removeComments(compilationUnit); return LexicalPreservingPrinter.print(compilationUnit); } private static void removeComments(CompilationUnit compilationUnit) { List<Comment> comments = compilationUnit.getAllContainedComments(); List<Comment> unwantedComments = comments .stream() .filter(CommentsRemover::isValidCommentType) .collect(Collectors.toList()); unwantedComments.forEach(Node::remove); } /** * 創建源碼解析器。我們設置LexicalPreservationEnabled為true,保留源碼中的所有語法。 * * @return JavaParser */ private static JavaParser createJavaParser() { ParserConfiguration parserConfiguration = new ParserConfiguration(); parserConfiguration.setLexicalPreservationEnabled(true); return new JavaParser(parserConfiguration); } /** * 我們只識別單行注釋和塊注釋 * * @param comment * @return true if meet the correct type */ private static boolean isValidCommentType(Comment comment) { return comment instanceof LineComment || comment instanceof BlockComment; } }
在上面的代碼中,我們首先創建JavaParser,再解析源碼,然后移除單行注釋和塊注釋,最后再用LexicalPreservingPrinter將處理后的源碼打印出來,這個打印器可以保留源代碼所有詞法,比如空格、換行之類的元素。上述代碼已有注釋,因此不再詳述。
考慮到我們平時可能會大量使用該功能,因此將其封裝為了IDEA插件,名為remove.comments。下面簡要介紹該插件的工作原理及使用方式。
PS:本文不會詳細介紹如何編寫IDEA插件。
IDEA插件的原理基本都是事件驅動,如下圖所示,我們創建了一個事件監聽器,當檢測到編輯器中點擊右鍵后,即可彈出菜單,我們的插件在菜單中的第一個位置。
接下來,實現事件處理器:
其中包含兩段核心代碼:
刪除源碼注釋。首先讀取當前文件內容也即源碼,然后交給前面已經介紹過的CommentsRemover.doAction處理,就拿到了刪除注釋后的源碼。
格式化代碼。刪除注釋后,可能會引入多余的空格,因此我們自動格式化,這樣用戶就不用再手動格式化一次了。
/** * 移除代碼中的注釋 * * @param editor * @return true if remove comments successfully */ private boolean removeComments(Editor editor) { String src = editor.getDocument().getText(); if (Strings.isNullOrEmpty(src)) { return false; } String dst = CommentsRemover.doAction(checkEndLineAndModifyIfNeed(src)); if (Strings.isNullOrEmpty(dst)) { return false; } editor.getDocument().setText(dst); return true; } /** * 由于我們保留了源碼格式,移除注釋之后會引入不必要的空格,因此需要再格式化一下 * * @param editor * @param project */ private void reformat(Editor editor, Project project) { PsiDocumentManager.getInstance(project).commitAllDocuments(); PsiFile file = PsiDocumentManager.getInstance(project).getPsiFile(editor.getDocument()); if (file == null) { return; } LastRunReformatCodeOptionsProvider provider = new LastRunReformatCodeOptionsProvider(PropertiesComponent.getInstance()); ReformatCodeRunOptions currentRunOptions = provider.getLastRunOptions(file); TextRangeType processingScope = TextRangeType.WHOLE_FILE; currentRunOptions.setProcessingScope(processingScope); (new FileInEditorProcessor(file, editor, currentRunOptions)).processCode(); }
然后打包插件:
插件打包好之后,用戶就可以從本地磁盤安裝了:
在彈出的目錄樹中,選中remove.comments.zip安裝包,確定即可。
重啟IDEA后,可以看到插件已安裝成功:
此時我們就可以使用該插件,一鍵刪除代碼中的注釋了。演示一下效果:
上述就是小編為大家分享的如何在IDEA中快速刪除Java代碼中的注釋了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。