我怎样才能避免在每个使用这个配置的函数中传递一个“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文件中。这就是为什么我避免使用全局变量
3条答案
按热度按时间bnl4lu3b1#
如果“configuration”对于应用程序的每个线程都是常量,则可以考虑全局定义它。
eoigrqb62#
如果配置对于每个线程都是常量,或者你没有使用线程,你可以使用全局变量。否则你可以使用Thread Local Storage,它就像一个全局变量,但特定于每个线程。
dm7nw8vv3#
为了扩展上述内容,您可能希望将依赖于此的所有函数收集到一个文件中,并在那里创建全局(或线程局部)变量
static
,以便将污染降至最低。