Java命令行界面(第2部分):args4j

上一篇文章中 ,我研究了如何使用Apache Commons CLI在Java应用程序中解析命令行参数。 在本文中,我将使用另一个库args4j进行相同的操作。

args4j采用了一种不同于Commons CLI的方式来指定Java应用程序应期望的命令行参数。 尽管Commons CLI期望代表选项的对象将被单独且显式实例化,但args4j使用自定义注释来促进命令行参数处理的这一“定义”阶段。 命令行选项应该是类上的实例级字段,并带有@ org.kohsuke.args4j.Option批注。 每个命令行参数的特征都包含在此@Option注释的属性中。

本文中演示的简单应用程序与我上一篇文章中使用的应用程序相似,并着重于用于指定详细程度的可选且无值的-v选项,以及所需的-f选项,该选项期望代表文件路径和名称的值。 下一个代码清单演示了如何使用args4j的@Option注释将这些命令行参数设置为类数据成员上的注释。

args4j通过@Option注释定义命令行参数

@Option(name="-v", aliases="--verbose", usage="Print verbose status.")
private boolean verbose;

@Option(name="-f", aliases="--file", usage="Fully qualified path and name of file.", required=true)
private String fileName;

如上面的代码清单所示,很容易指定选项的名称,用法以及是否需要(默认是可选的)。 上面的private修饰符的存在使它们很明显是在类级别定义的属性。 因为没有static修饰符,所以我们看到这些是已注释的实例变量。

要解析命令行选项,只需实例化一个CmdLineParser并将命令行参数传递给其parseArguments(String ...)方法:

解析args4j中的命令行参数

final CmdLineParser parser = new CmdLineParser(this);
try
{
   parser.parseArgument(arguments);
}
catch (CmdLineException clEx)
{
   out.println("ERROR: Unable to parse command-line options: " + clEx);
}

在刚刚显示的Java代码的第一行中, this是对类实例的引用,在该类实例中定义了上面显示的成员变量并使用@Option注释@Option注释。 在这种情况下,我使用this是因为定义这些选项的同一类是调用此解析方法的类。 为了在同一个类中执行此操作,我需要在类中定义一个名为doMain的实例(非static )方法,并由该类的main函数调用该方法(这在本文结尾处的完整代码清单中显示)。 从类的main(final String[])函数接收的命令行参数是传递给parseArguments(String[])方法的parseArguments(String[])数组。

接下来的两个屏幕快照演示了基于args4j的上述代码在解析命令行参数中的应用。 第一张图片显示了两个选项的短选项和长选项的组合。 第二个图像显示了自动报告未提供必需的命令行参数的情况。

命令行解析库的一个重要功能是能够显示用法或帮助信息。 下一个代码清单演示了使用args4j的CmdLineParser.printUsage(OutputStream)方法执行此操作的示例。

使用args4j打印使用情况信息

final CmdLineParser parser = new CmdLineParser(this);
if (arguments.length < 1)
{
   parser.printUsage(out);
   System.exit(-1);
}

下一个屏幕快照描述了args4j默认打印出的使用情况信息。

这篇文章演示了如何使用arg4j实现与Java应用程序中的命令行解析有关的一些最常见功能,包括选项“定义”,命令行参数“解析”,对所解析的命令行参数的“询问”以及帮助/ us与命令行参数有关的详细信息。 现在显示了上面在代码清单中部分表示的类的完整代码清单。

args4j演示Main.java的完整代码清单

package examples.dustin.commandline.args4j;

import static java.lang.System.out;

import org.kohsuke.args4j.CmdLineException;
import org.kohsuke.args4j.CmdLineParser;
import org.kohsuke.args4j.Option;

import java.io.IOException;

/**
 * Demonstrate args4j.
 */
public class Main
{
   @Option(name="-v", aliases="--verbose", usage="Print verbose status.")
   private boolean verbose;

   @Option(name="-f", aliases="--file", usage="Fully qualified path and name of file.", required=true)
   private String fileName;

   private void doMain(final String[] arguments) throws IOException
   {
      final CmdLineParser parser = new CmdLineParser(this);
      if (arguments.length < 1)
      {
         parser.printUsage(out);
         System.exit(-1);
      }
      try
      {
         parser.parseArgument(arguments);
      }
      catch (CmdLineException clEx)
      {
         out.println("ERROR: Unable to parse command-line options: " + clEx);
      }
      out.println("The file '" + fileName + "' was provided and verbosity is set to '" + verbose + "'.");
   }

   /**
    * Executable function demonstrating Args4j command-line processing.
    *
    * @param arguments Command-line arguments to be processed with Args4j.
    */
   public static void main(final String[] arguments)
   {
      final Main instance = new Main();
      try
      {
         instance.doMain(arguments);
      }
      catch (IOException ioEx)
      {
         out.println("ERROR: I/O Exception encountered: " + ioEx);
      }
   }
}

这是在选择框架或库来帮助Java进行命令行解析时要考虑的args4j的一些其他特征。

  • args4j是开放源代码,并已获得MIT许可证
  • 当前版本的args4j( 2.33需要 J2SE 5
  • args4j不需要单独下载或引用任何第三方库。
  • args4j 2.33主JAR( args4j-2.33.jar )的大小约为152 KB。
  • Maven存储库显示了376个对args4j的依赖关系 ,包括OpenJDK的JMH CoreJenkins (考虑到川口晃介的参与,这不足为奇)。
  • args4j已经存在了一段时间; 其2.0.3版本于2006年1月发布 ,至少从2003年开始就以某种形式出现。
  • args4j允许通过@Option注释上的“ hidden ”将命令行参数从使用情况输出中排除。
  • args4j允许指定和强制执行命令行参数之间的关系。 这包括指定何时不能同时提供两个参数的能力(“ 禁止 ”),以及仅当还提供了另一个参数时(“ depends ”)才有意义的情况。
  • args4j支持在有限的一组值适用于该选项的情况下使用枚举类型的类属性。 @Option文档在“枚举开关”部分下说明了如何执行此操作。
  • args4j通过其OptionHandler类提供了命令行参数解析的可扩展性和可定制性。

args4j库易于使用,并允许高度可读的代码。 决定是否使用args4j时,最大的考虑因素可能是确定使用批注指定命令行参数定义的舒适程度。

其他参考

翻译自: https://www.javacodegeeks.com/2017/06/java-command-line-interfaces-part-2-args4j.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值