在va_arg 64位问题 [英] va_arg 64bit issue

查看:315
本文介绍了在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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆