在mdl的debug的时候,输出字符串和数字,或者字符+数字,用sprintf,写一堆,而mdl中的ElementID是int ?uInt32还是?得判断好,你是不是觉得很麻烦,如果像c++的cout那样能够输出到mdl窗口就好了。
下面这个模板函数可以作为一个轻量级的解决方案:
typedef void(*outFuncP)(char*);
template<typename T>
void mdlDebugPrint
(
const T& val,
char* prefix = "",
char* postfix = "",
outFuncP funcP = mdlDialog_dmsgsPrint
)
{
std::stringstream ss;
ss<<prefix<<val<<postfix;
funcP(const_cast<char*>(ss.str().c_str()));
};
好了,现在我们可以不用sprintf了,直接用mdlDebugPrint就可以了。方便输出double,int,char,long,long long double……outFuncP用其他函数替换可将流输出到其它窗口。
但不能像cout一样连续输出、直到endl才清空缓存。怎么办?
可以自定义一个流.这个流非常非常简单,但功能却不小,因为它是通过继承而来的:
class mcout : public std::stringstream
{
public:
inline mcout& operator<<(mcout& ( __cdecl *fun)(mcout&) )
{
ASSERT(NULL != fun);
return ((*fun)(*this));
}
};
我们在定义一个类似std::endl的函数mdlendl就ok了,如下:
inline mcout& mdlendl(mcout& ms,outFuncP fP = mdlDialog_dmsgsPrint)
{
ASSERT(fP);
std::stringstream *ss = &ms;
fP(const_cast<char*>(ss->str().c_str()));
ss->str("");
return ms;
}
简单写个用法:
mcout mycout;
mycout<<"hello"<<"world"<<1234<<mdlendl;
为了保持一致性,最好是不用mdlendl这个名字,直接用endl,将其重载了更好。
如果用这个函数,就输出到messagecenter了:
inline mcout& msgEndl(mcout& ms)
{
return mdlendl(ms,mdlOutput_messageU);
}
因为重载了字符串流,所有关于流的操作都是可以的,比如流迭代器,通过它,可以快速将流输出:
//STDVectorDPoint3d lst; //this is ok also.
std::list<Dpoint3d> lst;
DVec3d pt;
BOOST_AUTO(itr,back_inserter(lst));
mdlVec_fromXYZ(&pt,0,0,0);
itr = pt;
mdlVec_fromXYZ(&pt,1,1,1);
itr = pt;
std::copy(lst.begin(),lst.end(),ostream_iterator<Dpoint3d>(mdlcout,"\n"));//快捷的流输出而不用循环语句
mdlcout<<endl;
(转载请说明出处:http://blog.csdn.net/mdlfans/article/details/7327286)