繁体   English   中英

引用使用argv []传递的全局变量

[英]Referencing global variables that are passed in using argv[]

我定义了一些类型为int的全局变量,并且希望它们与命令行参数匹配,以避免使用strcmpif语句无休止的链接。 例如,如果我定义了全局变量myvar ,并且用户键入myvar作为命令行参数,我希望能够引用myvar并使用argv[]对其执行操作。 能做到吗?

编辑我的问题只是为了使其更加清楚:

目前,我必须这样做:

int* A;
int* B;
int* C;

int set(void)
{
    if (strcmp((gargv[2]), "A") == 0)
    {
        *A = atoi(gargv[3]);
        return *A;
    }

    else if (strcmp((gargv[2]), "B") == 0)
    {
        *B = atoi(gargv[3]);
        return *B;
    }

    else if (strcmp((gargv[2]), "C") == 0)
    {
        *C = atoi(gargv[3]);
        return *C;
    }
    else 
    {
        errx(EX_USAGE, "Invalid");
    }
}


int main (int argc, char** argv) 
{
    gargv = argv;

    void* mem_chunk = calloc(5, sizeof(int));

    A = &mem_chunk[1];
    B = &mem_chunk[2];
    C = &mem_chunk[3];

    if (strcmp(argv[1], "set") == 0)
    {
        set();
    }
}

但是,只需要执行以下操作就不会那么麻烦,我可以将argv[2]设置为argv[3] ,并引用全局变量A,B或C:

int* A;
int* B;
int* C;

int set(void)
{
    gargv[2] = gargv[3];
    // example, if A and 10 given by user then set A = 10 and return
}

int main (int argc, char** argv) 
{
    gargv = argv;

    void* mem_chunk = calloc(5, sizeof(int));

    A = &mem_chunk[1];
    B = &mem_chunk[2];
    C = &mem_chunk[3];

    if (strcmp(argv[1], "set") == 0)
    {
        set();
    }
}

您的问题很模糊。 当然,您可以基于传递的命令行参数来设置全局变量,方法是先检查/解析argv设置所有配置变量。

实际上,这是命令行程序的典型结构,首先在程序中解析参数,然后在程序中解析参数,您仅使用在解析过程中设置的配置值和标志。

尚不完全清楚,但我想您也正在寻找简化命令行参数解析的工具。 好吧,有很多。 在* nix系统上,标准库中通常有getopt() (在POSIX中指定)。 注意,该手册页还描述了getopt_long() ,这是GNU扩展,仅可用于GNU C库( glibc )。

如果getopt()满足您的需求很简单,或者想在Windows之类的系统上使用它,请查看一个古老而知名的命令行解析库: popt 您可能会发现几乎所有使用google的系统的popt实现。

然后总有可能自己编写一次并自己重用。 我有我自己的,因为我需要一个经过状态分析的命令行界面,就像脚本语言一样,只是为了给您一个思路。


您的问题使我想到了这样的命令行:

> yourprogram foo=nanana bar=frobnicate

您想在程序中设置变量foobar 这不是使用带有可选参数和位置参数的开关的典型命令行界面,因此getopt()不能完全为您提供该信息。 但是,为此编写一个解析器非常容易,如下面的小演示所示:

#include <stdio.h>

// configuration for the parser:
struct argvVar
{
    const char *name;    // the name of the variable to look for
    const char **value;  // the address of the variable to set the value
};

void parseArgvVars(int argc, char **argv, const struct argvVar *vars)
{
    // loop over argv:
    for (int i = 1; i < argc; ++i)
    {
        // loop over configuration items:
        const struct argvVar *var = vars;
        while (var->name)
        {
            // compare variable name with current argument:
            const char *vname = var->name;
            const char *arg = argv[i];
            while (*arg && *vname)
            {
                // when different, try the next configured variable:
                if (*arg != *vname) goto nextVar;
                ++arg;
                ++vname;
            }
            if (*arg == '=')
            {
                // when matching and the following sign is an equals sign,
                // assign to the variable:
                *var->value = arg + 1;
            }
nextVar:
            ++var;
        }
    }
}

int main(int argc, char **argv)
{
    const char *foo = 0;
    const char *bar = 0;
    const char *baz = 0;

    // list of variables we want to assign from argv values:
    const struct argvVar vars[] = {
        {"foo", &foo},
        {"bar", &bar},
        {"baz", &baz},
        {0, 0} // end of list
    };

    parseArgvVars(argc, argv, vars);

    if (foo) printf("foo: %s\n", foo);
    if (bar) printf("bar: %s\n", bar);
    if (baz) printf("baz: %s\n", baz);

    return 0;
}

尝试了解配置结构的用法以及解析函数的一般性质,因此您可以学习如何一次解决问题并经常重复使用代码。

您必须使用getopt()或strncmp()。 例:

strncmp(argv[index], your_string, dim);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM