C语言 如何避免在使用此配置的每个函数中传递配置变量

cnwbcb6i  于 2023-03-28  发布在  其他
关注(0)|答案(3)|浏览(75)

我怎样才能避免在每个使用这个配置的函数中传递一个“config”变量。什么是最准确的方法来实现这样的行为。
这是我的代码:main.c

/* Complex Numbers Linking to proper variable */
typedef struct tagConfigNames {
    char name;
    complex *cnum;
} config_names;

/* Set command to function */
struct {
    char *name;
    void (*func)(config_names[]);
} cmd[] = {{"read_comp", read_comp}, {"print_comp", print_comp}, {"halt", halt},{"not_valid", NULL} };

int main()
{
    complex a,b,c,d,e,f;
    config_names cnumbers []= {{'a', &a}, {'b', &b}, {'c', &c}, {'d', &d}, {'e', &e}, {'f', &f},
                {'A', &a}, {'B', &b}, {'C', &c}, {'D', &d}, {'E', &e}, {'F', &f},
                {'#', NULL}};
    char command[30];
    int i;

    /* Run Forever */
    while(1) 
    {
        if (scanf("%s", command) == 1) {
            for (i = 0; cmd[i].func != NULL; ++i) {
                if (strcmp(command, cmd[i].name) == 0) 
                    break;
            }

            if (cmd[i].func == NULL) {
                printf("Error: no such command!\n");
            } else {
                (*(cmd[i].func))(cnumbers);
            }
        }
    }

    return 0;
}

complex.c

complex* find_complex_number(config_names cnames[], char ch)
{
    int i;
    for (i = 0; cnames[i].cnum != NULL; i++) {
        if (cnames[i].name == ch)
            break;
    }

    return cnames[i].cnum;
}

void read_comp(complex_names cnames[]) 
{
    //....

    if ((complex_num = find_complex_number(cnames, ch)) == NULL) {
        printf("Error: No such complex number\n");
        return;
    }
    //....
}

我实际上试图避免的是config_names cnumbers,它在每个函数中都传递。有没有更聪明的方法来处理这样的行为?
编辑:
我需要声明复数a,B,c,d,e,f;只在main.c文件中。这就是为什么我避免使用全局变量

bnl4lu3b

bnl4lu3b1#

如果“configuration”对于应用程序的每个线程都是常量,则可以考虑全局定义它。

eoigrqb6

eoigrqb62#

如果配置对于每个线程都是常量,或者你没有使用线程,你可以使用全局变量。否则你可以使用Thread Local Storage,它就像一个全局变量,但特定于每个线程。

dm7nw8vv

dm7nw8vv3#

为了扩展上述内容,您可能希望将依赖于此的所有函数收集到一个文件中,并在那里创建全局(或线程局部)变量static,以便将污染降至最低。

相关问题