我正在制作一个通用的记录器类,我打印任何传递到文件中的内容。
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 的重要性!您的问题不包括导致问题的非常重要的代码。