大家好,又见面了,我是你们的朋友全栈君。
getopt函数用来解析命令行选项,声明所在头文件为:
#include <unistd.h>
函数原型如下:
int getopt(int argc, char * const argv[], const char *optstring);
第一个参数argc是参数个数,和main函数的argc一样;
第二个参数argv是字符串指针,和main函数的argv一样;
第三个参数 optstring 是选项字符串,是本文所要讲述的重点。
选项字符串的内容如下:
还有一些错误处理:
针对字符后无冒号的设定:
针对字符后一个冒号的设定:
比如,"vha:b:c::"
就表示:
使用该函数时,会用到/设置四个全局变量:
extern char* optarg;
extern int optind;
extern int opterr;
extern int optopt;
#include <unistd.h>
#include <stdio.h>
int main(int argc, char * argv[])
{
int ch;
printf("初始值:optind = %d,opterr = %d\n", optind, opterr);
while ((ch = getopt(argc, argv, "vha:b:c::")) != -1)
{
printf("开始解析参数:optind = %d\n", optind);
switch (ch)
{
case 'v':
printf("捕获到选项: -v\n");
printf("系统版本v1.1.0\n");
break;
case 'h':
printf("捕获到选项: -h\n");
printf("用法示例: -a 1 -b 2 -c [\"hello\"]\n");
break;
case 'a':
printf("捕获到选项: -a\n");
printf("该选项参数为:%s\n\n", optarg);
break;
case 'b':
printf("捕获到选项: -b\n");
printf("该选项参数为:%s\n\n", optarg);
break;
case 'c':
printf("捕获到选项: -c\n");
printf("该选项参数为:%s\n\n", optarg);
break;
}
}
}
使用gcc编译:
gcc getopt_test.c -o getopt_test.o
单独测试每个选项:
测试都没有问题,接下来再看看几种错误的情况:
比如 -v 选项不需要参数,带个参数的结果如下:
再比如-a选项明确需要带一个参数,则带两个参数的结果如下:
如果不加参数,结果如下:
最后演示一个综合示例:
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/135394.html原文链接:https://javaforall.cn