C++以十进制打印的模板化流字符



我正在制作一个通用的记录器类,我打印任何传递到文件中的内容。

Logger::Instance()->write('c');
Logger::Instance()->write("this");
Logger::Instance()->write(5);

但是我遇到了一个问题,我有:

char c = 't';
Logger::Instance()->write(c);

打印十进制而不是 ascii:

116

字符串工作正常,但字符是唯一有问题的东西。

我的代码:

class Logger {
public:
    static Logger* Instance();
    bool open(string filename);
    template<typename T>
    void write(T data) {
        file << data;
    }
    bool close();

如果我制作特定于字符的打印功能:

void write(char data) {
    file << data;

它将打印字符。不知道这里发生了什么。

编辑 1:

只是一个总结..那么为什么这打印数字:

void write(T data) {
    file << data;
}

并打印正确的 ascii:

void writeChar(char data) {
    file << data;
}

???

编辑 2:

这是我的代码:

logger.h记录器.cpp

使用这个类,然后去:

char c = 't';
Logger::Instance()->write(t);
Logger::Instance()->writeChar(t);

编辑3:

好的..这是最后一个源文件。

[keyboardhook.cpp][3]
[keyboardhook.h][4]
[main.cpp][5]
[3]: http://pastebin.com/VEav4kfn
[4]: http://pastebin.com/yPwF17yg
[5]: http://pastebin.com/JwHz2NBe

看看这里:

if(isdigit(c)) {
        Logger::Instance()->write((char) c);
        Logger::Instance()->writeChar(c);
    } else if(isalpha(c)) {
        if(!shift)
            Logger::Instance()->writeChar(tolower((char) c));
        else
            Logger::Instance()->writeChar((char) c);

Stackoverflow一直将我的写作标记为"代码",并在保存时给我带来问题......抱歉等待。

我尝试了以下内容,它在Visual C++ 2010中运行良好(正如我所期望的那样):

#include <iostream>
struct Logger {
    template <typename T>
    void write(T data) {
        std::cout << data;
    }
};
int main() {
    Logger *log = new Logger;
    char c = 't';
    log->write(c);
    delete log;
}

也许您有一些自定义operator<<导致您出现此行为?你能发布一个 sscce 吗?

编辑:

为了将来参考,以下是为您的问题构成SSCCE的内容(基于您的完整代码):

#include <iostream>
struct Logger {
template <typename T>
    void write(T data) {
        std::cout << data;
    }
};
int main() {
    Logger *log = new Logger;
    char c = 't';
    log->write(tolower(c));
    delete log;
}

关键问题是tolower的签名是int tolower(int c)的,也就是说,它返回一个整数,而不是一个字符。因此,write<int>被称为,而不是write<char>.

请记住,sscce 的重要性!您的问题不包括导致问题的非常重要的代码。

最新更新