`
xiaozhonghua
  • 浏览: 253717 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

为你的Java代码批量设置头注释

阅读更多

大多正式一点的Java源代码,在头部都设有头注释信息,其中包含一些版权声明等信息。例如JDK的源码一般如下:

/*
* @(#)Object.java1.61 03/01/23
*
* Copyright 2003 Sun Microsystems, Inc. All rights reserved.
* SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
*/

package java.lang;

public class Object { .....}

如果我们有个小工具能把我们项目里所有目录下的Java代码统一设置头注释就好了;比如当版本信息等改变时,只要重新运行一下即可一次性更新。下面我们就来亲自写一个。

思路很简单:

  1. 建立一个窗口,用户可以设置一个目录、编写头注释信息;
  2. 查找目录下所有子文件,如果是Java文件则处理之,如果是目录则递归处理;
  3. 处理Java文件时,打开后,找到package语句或者第一个import语句,作为注释的插入点,插入注释;
  4. 将增加了头注释的文件内容写回文件。

本例中判断头注释插入点的逻辑比较简单,只是根据package语句或者第一个import语句来判断注释插入点,尚不严谨(比如原有的头注释中可能包含这些关键字),仅供参考。

HeaderCommentsGenerator

源码如下:

import java.io.*;
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;

public class HeaderCommentsGenerator {
private static int count = 0;

public static void main(String[] args) {
final JFrame frame = new JFrame("HeaderCommentsGenerator 1.0 [xiaozhonghua@hotmail.com]");
JPanel contentPane = (JPanel) frame.getContentPane();
JPanel centerPane = new JPanel(new BorderLayout(10, 10));
centerPane.setBorder(BorderFactory.createEmptyBorder(10, 10, 0, 10));
JPanel pathPane = new JPanel(new BorderLayout());
final JTextField txtPath = new JTextField();
txtPath.setText("Please select your file or path.");
pathPane.add(txtPath, BorderLayout.CENTER);
JButton btnSelectPath = new JButton("Browser...");
btnSelectPath.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
JFileChooser chooser = new JFileChooser();
chooser.setFileSelectionMode(JFileChooser.FILES_AND_DIRECTORIES);
int returnVal = chooser.showOpenDialog(frame);
if (returnVal == JFileChooser.APPROVE_OPTION) {
txtPath.setText(chooser.getSelectedFile().getAbsolutePath());
}
}
});
btnSelectPath.setMnemonic('B');
pathPane.add(btnSelectPath, BorderLayout.EAST);
centerPane.add(pathPane, BorderLayout.NORTH);
final JTextArea txtComments = new JTextArea();
txtComments.setText("/*\n" +
" * Copyright 2003-2004 ABC Software, Inc. All rights reserved.\n" +
" */");
centerPane.add(new JScrollPane(txtComments), BorderLayout.CENTER);

contentPane.add(centerPane, BorderLayout.CENTER);

JPanel buttonPane = new JPanel(new FlowLayout(FlowLayout.RIGHT, 10, 10));
JButton btnOK = new JButton("Generate!");
btnOK.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
String path = txtPath.getText();
File file = new File(path);
if (!file.exists()) {
JOptionPane.showMessageDialog(frame,
"Path '" + path + "' not exist.",
"Error",
JOptionPane.ERROR_MESSAGE);
} else {
commentFile(file, txtComments.getText());
JOptionPane.showMessageDialog(frame,
"Finish, total " + count + " files are processed.",
"Information",
JOptionPane.INFORMATION_MESSAGE);
}
}
});
btnOK.setMnemonic('G');
JButton btnClose = new JButton("Close");
btnClose.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
System.exit(0);
}
});
btnClose.setMnemonic('C');
buttonPane.add(btnOK);
buttonPane.add(btnClose);
contentPane.add(buttonPane, BorderLayout.SOUTH);

frame.setSize(500, 300);
frame.show();
}

private static void commentFile(File file, String comments) {
if (file != null && file.exists()) {
if (file.isDirectory()) {
String[] children = file.list();
for (int i = 0; i < children.length; i++) {
File child = new File(file.getPath() + System.getProperty("file.separator") + children[i]);
commentFile(child, comments);
}
} else {
if (file.getName().toLowerCase().endsWith(".java")) {
System.out.println(file.getName());
count++;
try {
RandomAccessFile raFile = new RandomAccessFile(file, "rw");
byte[] content = new byte[ (int) raFile.length()];
raFile.readFully(content);
String all = new String(content);
all = all.trim();
while (all.startsWith("\n")) {
all = all.substring(1);
}
if (all.indexOf("package") != -1) {
all = all.substring(all.indexOf("package"));
}
if (all.indexOf("import") != -1) {
all = all.substring(all.indexOf("package"));
}
all = comments + "\n" + all;
raFile.close();
FileWriter writer = new FileWriter(file);
writer.write(all);
writer.close();
}
catch (Exception ex) {
ex.printStackTrace();
}
}
}
}
}
}

希望这个小工具对你有点用处。

分享到:
评论
2 楼 cl1154781231 2014-10-23  
不错,关注,mark
1 楼 liushian 2011-11-18  
调试通过!
顶!

相关推荐

    清除Java代码注释

    当然,对于非程序员或者希望快速操作的用户,也有一些第三方工具可以实现批量清除Java代码注释,例如Java Comment Remover等。这些工具通常具有用户友好的界面,只需选择目标文件或目录,然后点击“清除注释”按钮...

    java_SQL文件批量删除注释

    java_SQL文件批量删除注释 ,实现自动批量处理Sql脚本中的注释,方便发布您自己的脚本,简单好用。亲测可以用的,谢谢支持。

    C/C++/Java 源代码注释清除工具

    描述中提到的“可以对文件夹操作”意味着该工具支持批量处理,用户可以指定一个包含多个源代码文件的目录,工具会遍历其中的所有C、C++和Java文件,并逐一删除注释。这种批量处理能力极大地提高了工作效率,尤其是在...

    sourceinsight 多行注释 批量注释 反注释

    批量注释允许你一次性对多行代码添加注释,这对于文档更新或者暂时禁用某段代码非常方便。在Source Insight中,你可以这样做: - 使用查找与替换功能:打开查找对话框(`Ctrl+F`),在“查找”栏输入要注释的代码...

    自主研发的批量保留路径清理代码注释工具

    聪哥创作的一款批量保留路径清理代码注释的工具,目前兼容大部分常见的代码注释,涵盖c、java、python、php、js、html、css、mysql、node、vue、ruby等常见编程项目的注释无损清理。 2023年8月19日更新日志: 1.对...

    去除源代码注释

    - **Java解析器**:更专业的方式是使用Java解析库,如ANTLR、JavaCC等,它们能解析Java语法结构,区分代码和注释,从而方便地去除注释。 - **IDE插件**:许多集成开发环境(IDEs),如Eclipse和IntelliJ IDEA,...

    代码注释删除小工具(java)

    用java编写的代码注释删除小工具,能去文本中掉//和/* */注释。 第一个按钮的功能为去掉文本框1中代码的注释,输出到文本框2. 第二个按钮的功能为批量删除文件中的注释,并输出到当前目录(新文件名为xxx.txt)。但...

    批量增加注释小助手.jar

    "批量增加注释小助手.jar" 是一个专为Java开发者设计的工具,它简化了在大量源代码中添加注释的繁琐过程。这个程序可能是用Java语言编写的,并且以jar(Java Archive)格式打包,使得用户可以在任何安装了Java运行...

    批量替换程序的文件注释头

    标题提到的"批量替换程序的文件注释头"就是一个很好的例子,它涉及到的是如何自动化地修改代码文件中的特定部分,例如版权信息、作者声明或者项目标识等注释内容。这种操作在更新项目版本、迁移代码库或者统一团队...

    去掉代码注释的工具java \ c\c++、php等

    对于Java代码,我们可以使用如JRemoval这样的工具。JRemoval是一个开源的Java源代码处理工具,它可以快速地从Java源代码中删除单行和多行注释,同时保留代码的原始结构。通过简单的命令行参数配置,你可以轻松地...

    文件批量重命名java源代码

    这个名为"文件批量重命名java源代码"的项目,提供了实现这一功能的源代码,其中包含丰富的注释,适合初学者或者需要理解文件操作的开发者进行学习。 在Java中,我们主要使用`java.io`包中的类来处理文件和目录。在...

    Java 删除项目里面的注释所用到的包.zip

    在Java开发过程中,有时我们需要对项目进行优化或者清理,这时可能会涉及到删除代码中的注释。这个"Java 删除项目里面的注释所用到的包.zip"可能包含了一个或多个工具或库,专门用于自动化删除Java源代码中的注释。...

    几种常用的注释 和 利用工具替换注释代码

    例如,你可以选择一段代码,然后使用快捷键或菜单选项将其转换为注释或取消注释。 2. 版本控制工具: Git等版本控制工具在合并代码时,有时会遇到冲突,这时可以使用其内置的命令或第三方工具来帮助解决,这些工具...

    Java代码行计算工具

    Java代码行计算工具是一款专为Java开发者设计的实用软件,用于统计Java源代码中的代码行数、注释行数以及空白行数。这样的工具对于软件工程的代码质量管理、项目进度评估以及代码复杂度分析具有重要意义。 在软件...

    java源码注释翻译

    Java源码注释翻译是一个重要的开发工具,尤其对于那些阅读英文源码或处理国际开源项目时,能够快速理解和学习代码的含义。这个项目的核心目标是批量处理Java源码文件,将其中的类注释自动翻译成中文,以帮助开发者...

    mybatisr代码生成插件(中文注释,生成批量插入及修改)

    MyBatis Generator(MBG)是一款强大的代码生成工具,它能够自动为数据库中的表生成Java实体类、Mapper接口以及XML映射文件等,极大地提高了开发效率。在这个自定义版的MBG插件中,它特别加入了中文注释,使得代码更...

    source insight comment 添加代码注释

    1. **实时注释编辑**:Source Insight支持多种编程语言,如C、C++、Java等,并允许用户在代码行旁边实时添加、修改和删除注释。只需在代码行尾部输入`//`(单行注释)或`/* */`(多行注释)即可开始编写注释。 2. *...

    Java做客户端对Elasticsearch服务的增删改查及批量修改操作

    Java做客户端对Elasticsearch服务的增删改查及批量修改操作,代码简洁易懂,思路清晰有注释.详情参考https://blog.csdn.net/linhaiyun_ytdx/article/category/7042758

    清理代码注释和空行

    另外,许多代码编辑器和IDE(如Visual Studio Code、IntelliJ IDEA)提供了批量修改和格式化的功能,包括注释和空行的处理。 软件著作登记时,清理代码可能是因为原始代码包含了敏感信息或者版权声明,这些信息在...

    批量去出php多行版权注释

    然而,有时候出于特定需求,例如代码整合或者二次开发,我们可能需要批量去除代码中的原有版权注释并替换为自己的版权信息。针对这个主题,我们将深入探讨如何使用PHP编写脚本来实现这一目标。 首先,我们需要理解...

Global site tag (gtag.js) - Google Analytics