在va_arg 64位问题 [英] va_arg 64bit issue
本文介绍了在va_arg 64位问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有这样的C $ C $℃。在64位Linux系统的结果是:4294967264,而不是-32。 无论铛和gcc产生二进制相同的不正确的结果。 在该行的问题:
* V =在va_arg(参数长);
的#include< stdio.h中>
#包括< string.h中>
#包括< STDARG.H>
无效二传手(长* V,...)
{
va_list的ARGS;
的va_start(参数,V);
* V =在va_arg(参数长);
va_end用来(参数);
}
诠释的main()
{
长ν= 0;
二传((长*)及V,-32);
的printf(%LD \ N,V);
返回0;
}
解决方案
您确实需要传递长
给你的函数。你传递一个 INT
。
二传手(安培; V,-32L);
I've such C code. On 64-bit linux system the result is: 4294967264 instead of -32. Both clang and gcc produce binary with same incorrect results. The problem in the line:
*v = va_arg(args, long);
#include <stdio.h>
#include <string.h>
#include <stdarg.h>
void setter(long *v, ...)
{
va_list args;
va_start(args, v);
*v = va_arg(args, long);
va_end(args);
}
int main()
{
long v = 0;
setter((long *) &v, -32);
printf("%ld\n", v);
return 0;
}
解决方案
You actually need to pass a long
to your function. You're passing an int
.
setter(&v, -32L);
这篇关于在va_arg 64位问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文