用main(int argc,char **argv){}作为函数重写程序



我想重写一个以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(参数向量)中获得数据。你不需要做你想做的事情,只要让它变得简单。

相关内容

  • 没有找到相关文章

最新更新