Java main方法的args是JVM传入的原始String[]数组,不解析选项语法;需手动或借助库处理短选项、键值对等,如java MyApp -v --port 8080 "log file.txt"得["-v","--port","8080","log file.txt"]。
Java 的 main 方法接收的命令行参数是一个 String[] 数组,它不自动解析选项(如 -h、--output=file.txt),需要手动处理或借助工具库。核心在于理解参数传递机制,并选择合适方式提取和验证。
public static void main(String[] args) 中的 args 是 JVM 启动时从命令行传入的、空格分隔的字符串数组(引号内空格会被保留)。例如:
java MyApp -v --port 8080 "log file.txt"
args = ["-v", "--port", "8080", "log file.txt"]
注意:JVM 不做语法解析,不会识别短
选项合并(如 -abc)、键值对绑定或类型转换,这些都需自行实现或依赖库。
若参数结构固定且数量少,可用循环 + 字符串判断快速处理:
for (int i = 0; i 遍历,检查 args[i] 是否为标志(如 "-h")或选项名(如 "--input")
--file data.txt),取 args[i+1],并确保 i+1
args[i].startsWith("-") 区分选项与位置参数(如输入文件名)ArrayIndexOutOfBoundsException
Apache Commons CLI 是轻量、成熟的命令行解析库,支持 POSIX/GNU 风格语法、自动帮助生成、类型转换和错误提示:
commons-cli
Options 对象,声明选项(如 Option.builder("o").longOpt("output").hasArg().argName("FILE").build())DefaultParser 解析 args 得到 CommandLine
cmd.hasOption("o") 或 cmd.getOptionValue("o") 安全获取值new HelpFormatter().printHelp(...) 自动生成帮助信息Picocli 支持注解驱动、子命令、自动补全、颜色化帮助页,且零依赖、单文件可嵌入:
@Option 注解字段(如 @Option(names = {"-v", "--verbose"}) boolean verbose;)@Parameters 接收剩余位置参数(如输入文件列表)Runnable 或 Callable,调用 new CommandLine(new MyApp()).parseArgs(args)