- getopt() - 分析命令行选项
SYNOPSIS
#include <unistd.h>
int getopt(int argc, char * const argv[],
const char *optstring);
extern char *optarg;
extern int optind, opterr, optopt;
optarg——指向当前选项参数(如果有)的指针。 optind——再次调用 getopt() 时的下一个 argv 指针的索引。 optopt——最后一个未知选项。
getopt返回值: 选项
如果optstring的字母后接着冒号“:”,则表示还有相关的参数,全域变量optarg 即会指向此额外参数。如果在处理期间遇到了不符合optstring指定的其他选项getopt()将显示一个错误消息,并将全域变量optarg设为“?”字符,如果不希望getopt()打印出错信息,则只要将全域变量opterr设为0即可。
例如: getopt(argc, argv, "ab:c:de::");
1.abcde都是命令行的一个选项
2.b:c: 表示-b -c后面都需要接一个参数,紧跟选项后或空格隔开。optarg指向该参数。
3.e:: 表示-e 可以跟一个参数,也可以不跟。如果跟一个参数,参数必须紧跟在选项后不能以空格隔开。该参数的指针赋给optarg。(如上例中的e::,如果没有跟参数,则optarg = NULL)
实例:
#include <stdio.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
int ch = 0;
opterr = 0;
while((ch = getopt(argc,argv,"a:bcde::")) != -1){
switch(ch){
case 'a':
printf("option a:'%s'
", optarg);
break;
case 'b':
printf("option b :'%s'
", optarg);
break;
case 'e':
printf("option e:'%s'
", optarg);
break;
default:
printf("other option : %c
", ch);
}
printf("optopt +%c
", optopt);
}
return 0;
}
结果如下:
可知-e不带参数也没问题。-a不带参数不能识别,返回?,且optopt = a。
xxx@xxx-pc:~/Documents$ ./a.out -b
option b :'(null)'
optopt +
xxx@xxx-pc:~/Documents$ ./a.out -e123
option e:'123'
optopt +
xxx@xxx-pc:~/Documents$ ./a.out -e
option e:'(null)'
optopt +
xxx@xxx-pc:~/Documents$ ./a.out -a
other option : ?
optopt +a
xxx@xxx-pc:~/Documents$ ./a.out -a333
option a:'333'
optopt +