- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我做了一个简单的测试用例:
static void va_test(char* str_arg, ...)
{
va_list ap;
va_start(ap, str_arg);
for( ; ; ) {
if (str_arg == NULL)
break;
int n = va_arg(ap,int);
printf("arg: %s,%d\n", str_arg, n);
str_arg = va_arg(ap,char*);
}
va_end(ap);
printf("\n");
}
当我在独立的可执行文件中使用 va_test("beer",1,"cofe",2,"juice",3,0)
运行它时,它工作正常。但是当我从我的项目可执行文件中调用它时,它非常大,它会给出一些像这样的垃圾字符串:
arg: bear,1
arg: cofe,2
arg: juice,3
arg: ^X(garbage...),57
我猜肯定是调用这个函数之前发生了内存困惑,但是我该如何调试呢?
[编辑]我稍微更新了描述,因为严格来说,错误发生在我将超过 6 个参数传递给 va_test 时。我意识到前六个 64 位参数在 amd64 机器中通过寄存器传递,而其他参数通过堆栈传递。当 va_arg 尝试从 *overflow_arg_area
获取第一个 arg 时会出现问题。
最佳答案
对我来说最有可能的解释是,您所处的系统中 int
0 与 char *
0 具有不同的表示形式。这可以在一个 64 位系统,其中 sizeof(int) == 4
和 sizeof(char *) == 8
。
尝试将最后一个参数作为 (char *) 0
而不是 0
传递,你应该没问题。所有其余代码在技术上看起来都是正确的。
关于c - va_arg 给出垃圾文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8132678/
我有以下函数将传递的参数写入二进制文件。 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
我是一名优秀的程序员,十分优秀!