- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想像这样用指针参数初始化一个链表:
/*
* Initialize a linked list using variadic arguments
* Returns the number of structures initialized
*/
int init_structures(struct structure *first, ...)
{
struct structure *s;
unsigned int count = 0;
va_list va;
va_start(va, first);
for (s = first; s != NULL; s = va_arg(va, (struct structure *))) {
if ((s = malloc(sizeof(struct structure))) == NULL) {
perror("malloc");
exit(EXIT_FAILURE);
}
count++;
}
va_end(va);
return count;
}
问题是 clang 错误 type name requires a specifier or qualifier
at va_arg(va, (struct structure *))
,并表示类型说明符默认为诠释。它还在 (struct structure *)
和 struct structure *
处记录了实例化形式。这似乎被分配给 s
的是 int (struct structure *)
。
当从 (struct structure *)
中删除括号时,它可以正常编译,但是无法访问应该初始化的结构。
为什么当括号围绕传递给 va_arg 的类型参数时假定为 int
?我该如何解决这个问题?
最佳答案
va_arg
是许多系统上的宏,显然 struct structure *
周围的括号导致宏扩展为无法解析的内容。所以不要那样做。
这与您的初始化结构“不可访问”的原因无关。您正在分配结构并将它们分配给 s
,但 s
是局部变量。您不能通过分配给局部变量来影响调用者中的值。为了完成你想做的事情,调用者需要传递一个指向指针的指针,然后你可以初始化它
int init_structures(struct structure **first, ...)
{
struct structure **s;
unsigned int count = 0;
va_list va;
va_start(va, first);
for (s = first; s != NULL; s = va_arg(va, struct structure **)) {
if ((*s = malloc(sizeof(struct structure))) == NULL) {
perror("malloc");
exit(EXIT_FAILURE);
}
count++;
}
va_end(va);
return count;
}
调用者应该这样做:
struct structure *a, *b;
init_structures(&a, &b, NULL);
关于c - 带指针的 va_arg,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2845638/
我有以下函数将传递的参数写入二进制文件。 void writeFile(FILE *fp, const int numOfChars, ...) { va_list ap; va_star
我正在制作一个类似于 printf 的函数,它需要接受一个字符串和参数,例如: form("整数 %d, 字符串 %s", 54, "STRING"); 并创建一个字符串“Integer 54,Str
为什么下面的代码给出EXC_BAD_ACCESS, could not access memory ? int combine_strings(char **outputStr,...) {
我的打印函数使用 va_arg 函数打印随机字符。我不明白为什么它不起作用。提前感谢您的帮助! #include #include #include int myprint(const char
在 main.c 中,我调用 function(2, "string", "yes") 哪里 void function(UINT16 id, const char *ptr_argDescr,
我想用这种方式编写一个带有可变参数的函数: static void configElement(U32 localFaultId, char* na
我正在研究可变函数和参数。 我注意到 va_arg 能够将对象转换为其他对象。例如,当下一个参数是 char 时,但您正在使用 va_arg 就像它应该是 int 一样,它会转换 char 到 int
我可以将类型转换为 va_arg 返回示例吗?据我所知,va_arg 无法读取返回 char/short int 类型 if (flags->size == 0) u->s = (char)v
我正在尝试编写一个带有格式字符串和一些可变数字参数的小函数。格式字符串采用表示不同数字类型的各种字符(c 表示 char,i 表示 int,d 表示 double 等),然后字符串中的每个字符采用该类
我是第一次尝试编写自己的 va_args 函数,但我遇到了一个问题,即大整数(仍在 int 范围内)被截断为 3 位数字,并且乱序! 这里是实现 void __sprintf(char * _stri
如果我调用 va_arg 的次数少于可变参数函数中传递的参数数量,是否会出现未定义的行为? 例如: #include void foo(unsigned n, ...) { va_list
全部, 我正在编写一个小型 C++ 应用程序,但一直被这个问题难倒。如果元素类型不是预期的,是否有一种方法可以在使用 va_arg 从 va_list 宏访问元素时创建(并稍后捕获)错误。例如:- c
使用以下代码,va_arg 将在第二次和第三次通过 vProcessType 时返回垃圾。 // va_list_test.cpp : Defines the entry point for the
我正在尝试创建一个函数,该函数在参数中采用可变数量的矩阵并将这些矩阵乘以第一个。我可以使用 va_arg 读取第一个,但下一次调用 va_arg 将导致访问冲突。 这是我声明方法的方式: templa
我做了一个简单的测试用例: static void va_test(char* str_arg, ...) { va_list ap; va_start(ap, str_arg); for
我想像这样用指针参数初始化一个链表: /* * Initialize a linked list using variadic arguments * Returns the number of
mystruct_t v = va_arg(a_list, mystruct_t); 就 C 规范而言,这可以吗(使用大于等于 int 大小的自定义数据类型)? 最佳答案 C 标准中没有关于将结构类型
我正在阅读一个 stdarg.h(下面的链接)头文件,它定义了 va_arg 宏,如下所示 /* * Increment ap to the next argument in the list wh
我知道如果我将像 void (*func)(void *) 这样的参数传递给可变参数函数,我可以像这样检索参数: void (*func)(void *) = va_arg( args, void (
这个问题不太可能对任何 future 的访客有帮助;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于互联网的全局受众。如需帮助使这个问题更广泛适用,visit the h
我是一名优秀的程序员,十分优秀!