项目场景:
往日志缓冲类里传入日志流的char*字符
问题描述
例如:本应该输出的字符串却变为16进制混乱字符
m_logallfile[severity]->GetLogBufStream()<< (ls.str()) //输出0x123ad132
//getlogbufstream()是返回流的引用
原因分析:
写了test发现函数没问题,但是在互联网搜索后发现 是由于括号的问题,我本意是在str外包裹一层括号使结果明了,但是使得编译器对函数重载参数误判成 void类型 以上语法调用成员函数ostream::operator<<()这是没有定义的char也不是为了string. 它只定义为void*它总是以十六进制显示地址。
解决方案:
(m_logallfile[severity]->GetLogBufStream())<< ls.str() ;
更换了包裹对象使意图清晰.
结语:
顺带一提,那个外国老哥也是在写log模块时踩坑了哈哈.
但是这也反映了我对stream一系列使用的无知,很多写法都是想当然的.对于一些标准库的使用今后要上心!