转发省略号args时丢失数据

时间:2012-04-01 18:17:37

标签: c++ debugging visual-c++

我希望有一个可移植的调试类,因为我计划在各种平台上处理该项目。这个类提供了通过XDebug.WriteLine写入消息的方法(“我喜欢数字%d”,7);其中内部将参数重定向到系统特定方法。

这要求我将省略号数据作为参数传递。这就是问题所在。它适用于整数,但在通过时会丢失浮点数。

XDebug::WriteLine("Print numbers %f, %f",1.234, 3.210f);
XDebug::odprintf(L"Print numbers %f, %f",1.234, 3.210f);

输出

Print numbers 0.000000, 0.000000
Print numbers 1.234000, 3.210000

我试图找出参数被破坏的地方。非常感谢你的帮助。整个调试类如下。

#pragma once
#ifndef _XDEBUG_H_
#define _XDEBUG_H_

#include <stdio.h>
#include <stdarg.h>
#include <ctype.h>
#include <Windows.h>;

class XDebug
{
public:

    static void __cdecl WriteLine(const char* txt, ...){
        #if (CC_TARGET_PLATFORM == CC_PLATFORM_WIN32)

        int stringSize = MultiByteToWideChar (CP_ACP, 0, txt, -1, NULL, 0);
        wchar_t* buffer = new wchar_t[stringSize];
        MultiByteToWideChar(CP_UTF8 , 0 , txt, -1, buffer, stringSize);

        va_list args;
        va_start(args, txt);
        XDebug::odprintf(buffer,args);

        delete buffer;

        #endif
    }

//private:
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WIN32)
    static void __cdecl odprintf(const wchar_t *format, ...){
    wchar_t    buf[4096], *p = buf;
    va_list args;
    int     n;

            va_start(args, format);
            n = _vsnwprintf(p, sizeof buf - 3, format, args); // buf-3 is room for CR/LF/NUL
            va_end(args);

            p += (n < 0) ? sizeof buf - 3 : n;

            while ( p > buf  &&  isspace(p[-1]) )
                    *--p = '\0';

            *p++ = '\r';
            *p++ = '\n';
            *p   = '\0';

            OutputDebugString(buf);
    }
#endif
};

#endif

1 个答案:

答案 0 :(得分:2)

你不能在这样的函数之间转发varargs,原因与你无法将args直接传递给sprintf(你必须使用特殊的vsprintf)。

我建议写一个odprintf的重载,它将va_list个对象作为参数。 (为避免duplication,您可以根据新的重载实现原始的odprintf。)