
本文将演示如何使用C语言解析命令行参数。以下代码实现了一个简单的命令行参数解析器,能够处理文件路径、布尔标志和整数值。
#include#include #include #include // 定义结构体存储命令行参数 typedef struct { char* filepath; bool myflag; int myvalue; } cliargs; // 错误处理函数 static inline void error(const char* message) { fprintf(stderr, "%s\n", message); exit(1); } // 命令行参数解析函数 cliargs parse(int argc, char** argv) { cliargs cli_args = { .filepath = NULL, .myflag = false, .myvalue = 0 }; if (argc == 1) error("未传入任何参数。"); // 解析参数 for (int i = 1; i < argc; ++i) { if (argv[i][0] == '-') { // 参数以'-'开头 if (strcmp(argv[i], "--myflag") == 0) { cli_args.myflag = true; } else if (strcmp(argv[i], "--myvalue") == 0) { if (i + 1 >= argc) { error("未为--myvalue参数指定值。"); } char* endptr; long value = strtol(argv[i + 1], &endptr, 10); if (*endptr != '\0' || value > INT_MAX || value < INT_MIN) { error("无效的--myvalue参数值。"); } cli_args.myvalue = (int)value; i++; // 跳过下一个参数,因为它已经是值 } else { error("未知参数。"); } } else { // 假设第一个非'-'参数为文件路径 if (cli_args.filepath != NULL) { error("只能指定一个文件路径。"); } cli_args.filepath = argv[i]; } } return cli_args; } int main(int argc, char** argv) { cliargs args = parse(argc, argv); printf("./cli_args was called:\n"); printf("%s is the filepath, myflag is %s and myvalue is %d.\n", args.filepath ? args.filepath : "NULL", args.myflag ? "true" : "false", args.myvalue); return 0; }
使用方法:
-
编译代码:
gcc cli_args.c -o cli_args
php 配置文件php.ini的中文注释版(09.4)下载在WINDOWS下,编译时的路径是WINDOWS安装目录。 ; 在命令行模式下,PHP.INI的查找路径可以用 -C 参数替代。 ; 该文件的语法非常简单。空白字符和用分号&ACUTE;;&ACUTE;开始的行被简单地忽略(就象你可能 ; 猜到的一样)。 章节标题(例如 : [FOO])也被简单地忽略,即使将来它们可能 ; 有某种的意义。 ; ;
-
运行程序,并传入参数:
-
./cli_args foo.txt(仅指定文件路径) -
./cli_args foo.txt --myvalue 123(指定文件路径和整数值) -
./cli_args foo.txt --myflag --myvalue 456(指定文件路径、布尔标志和整数值)
-
该程序对错误进行了处理,并提供更清晰的输出信息。 请注意,此示例中只处理了--myflag 和 --myvalue 两个参数,可以根据实际需求扩展参数处理逻辑。









