c++ - 当我使用可变参数时,它适用于 int 和 double,但是当涉及到 float 时,就会出错

标签 c++ c visual-studio-2008 visual-c++ c++11

当我使用可变参数时,它适用于 int 和 double,但是当涉及到 float 时,就会出错。

这是代码。

void vaParamTest(int a, ...)
{
    va_list ap;
    va_start(ap, a);
    for (int  i = 0; i < a; i++)
        printf("%f\t", va_arg(ap, float));
    putchar('\n');
    va_end(ap);
}

我这样传递参数。

vaParamTest(3, 3.5f, 8.3f, 5.1f);

最佳答案

作为可变函数参数传递的变量是默认提升,这使得所有float都变成了double。你永远不能有一个 float 参数(就像 you can never have a char argument )。在 printf 中,%f 始终表示 double

关于c++ - 当我使用可变参数时,它适用于 int 和 double,但是当涉及到 float 时,就会出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12363314/

相关文章:

visual-studio-2008 - 如何重建 Visual Studio 工具箱?

asp.net - Visual Studio 2008 ASP.Net 调试僵尸断点被删除后又回来了

python - Microsoft Visual C++ 2008 Redistributable Package 可以自由再分发吗

C++ 构造函数、常量、继承和避免重复

c++ - Tesseract OCR 的置信度值

c - 从堆栈的角度来看,为什么 main 函数与其他函数不同

c - lambda 表达式

c++ - osx - 构建 POCO 库时出现链接错误

c++ - NodeJS : node-gyp compile with the equivalent gcc -lm option

c - C 中的链表和结构体