我想重写一个以main(){}开头的程序,以便我可以将其用作函数。通常,程序需要一个输入文件、一个输出文件和最多6个可选参数。我在命令行中使用:
传递它们programname --opt1 --op2 --op3 <input file> output file
程序中的不同参数然后由getopt_long (int argc, char *const *argv, const char *shortopts, const struct option *longopts, int *indexptr)
读取。
当我想用这个创建一个函数时我必须将名称main()
转换为其他名称,比如programname()
,此外我必须直接传递参数,所以从
main(int argc, char **argv){}
变成了例如:
main(int opt1, int opt2, int opt3, FILE *infile, FILE *outfile){}
我的问题是:我如何管理输入参数数量的可选性?与getopt_long
我可以使用--opt1
而不是-opt1
来管理这一点,但getopt_long
可以在主要功能中使用,还是?我能不能创建一个没有指定输入数的函数?
谢谢你的帮助!
编辑:现在我尝试用scanf()
从user读取argv一个小例子,你可以试试:第一个输入:——dd=2第二个输入:ok
#include <getopt.h>
void main(){
char **options = (char**) malloc(6*sizeof(char*));
int i;
for(i=0;i<6;i++){
options[i] = (char*) malloc(100*sizeof(char));
}
int argc=1;
printf("%sn", "insert your options. e.g.: [--ngf=20]");
printf("%sn", "if finished press [ok]");
scanf("%s",options[argc]);
while (strcmp(options[argc],"ok")!=0){
argc++;
scanf("%s",options[argc]);
}
char **argv = (char**) malloc(argc*sizeof(char*));
for(i=0;i<argc;i++){
argv[i] = (char*) malloc(100*sizeof(char));
}
for(i=0;i<argc;i++){
argv[i] = options[i];
}
/* Process Arguments */
optind = 1;
double aa,bb,cc;
int c, dd;
int option_index = 0;
static struct option long_options[] = {
{"aa", 1, 0, 1},
{"bb", 1, 0, 2},
{"cc", 1, 0, 3},
{"dd", 1, 0, 4},
{0, 0, 0, 0}
};
while ((c = getopt_long(argc,argv,"hgt",
long_options, &option_index)) != -1) {
switch (c) {
case 1: if (sscanf(optarg,"%lg",&aa) != 1)
fun_Stop("incorrect format");
break;
case 2: if (sscanf(optarg,"%lg",&bb) != 1)
fun_Stop("incorrect format ");
break;
case 3: if (sscanf(optarg,"%lg",&cc) != 1)
fun_Stop("incorrect format");
break;
case 4: if (sscanf(optarg,"%i",&dd) != 1)
fun_Stop("incorrect format");
break;
default :
break;
}
}
}
有几种可能性:
1)你保持接口完整。这意味着你必须在调用代码时自己构建argc argv。这样的:
void myfunction(int argc, char **argv);
...
char *arguments[5]={"whatever","--opt1","--opt2","blabla","blablabla"};
myfunction(5,arguments);
可以像以前一样使用getopt_long。请注意,第一个参数argv[0]是程序的名称(在这种情况下无关紧要),而不是第一个参数,它在argv[1]中。
或
2)如果你的选项只是二进制的开/关事务,你可以将你的选项定义为可以在位域中组合的常量。这样的:
typedef enum {opt1=1, opt2=2, opt3=4, opt4=8} Opts;
void myfunction(unsigned long opts, char *input, char *output)
{
if(opts&opt1)
printf("Option 1!n");
...
}
...
myfunction(opt1|opt2,"blabla","blablabla");
这应该取决于体系结构,有32或64个不同的选项。
自己解析argc/argv>o<</p>
if (argc >= 2)
{
for (int i = 1; i < argc; i++)
{
char * const arg = argv[i];
// parse..
}
}
或者,您可以使用Boost.ProgramOptions。(如果使用c++)
在argc和argv中已经完成了。你传递给程序的参数数量由操作系统存储在argc(参数计数器)中,然后你可以在argv(参数向量)中获得数据。你不需要做你想做的事情,只要让它变得简单。