我正在编写一个程序,该程序最多可以包含3个选项,同时也可以将它们组合在一起。该部分如下所示:
char flag = 0; // to mark which options were set
int aopt = INT_MAX; // default to INT_MAX if no args delivered
char bemerkung[100];
memset(bemerkung, '\0', 100); // string to receive via '-b'
char option;
while((option = getopt (argc, argv, "m:a:b:")) != EOF){
switch( option ){
case 'm': {
flag = flag | 1;
break;
}
case 'a': {
flag = flag | 2;
char * arg = optarg;
aopt = atoi(arg);
if(aopt == 0 && strcmp("0", arg) != 0) // if no valid optarg was entered
aopt = INT_MAX; // get back the default value
break;
}
case 'b': {
flag = flag | 4;
strcpy(bemerkung, optarg);
break;
}
default: {
fprintf(stderr, "Unknown option entered.\n");
return -1;
}
}
}
// some code here, not touching `flag`
if(flag == 1){
// deal with `-m`, no optargs
}
if(flag == 2){
// `-a aopt` called
}
if(flag == 3){
// `-m -a aopt` called
}
基本思想是设置flag
中的位,以便我以后可以处理选项及其组合。但是我现在面临的麻烦是-m
需要参数(仅对于-m
是可选的),并且./main -m -a 0
的结果将变成flag = 1
而不是flag = 3
。 / p>
我如何使-m
的参数成为可选参数,并使OR
正确完成flag
?
答案 0 :(得分:1)
如果您希望-m
不接受任何参数,请在选项字符串中省略其后的:
。 :
意味着前面的选项需要一个参数:
while((option = getopt (argc, argv, "ma:b:")) != EOF){