我正在使用一个记录模块,可以在运行时启用/禁用报告.通话通常是这样的:
WARN( "Danger Will Robinson! There are " + boost::lexical_cast<string>(minutes) + " minutes of oxygen left!" );
我正在使用WARN的内联函数,但是我很好奇幕后进行了多少优化 – 对整个程序中的参数进行评估将是非常昂贵的. WARN功能如下:
bool WARNINGS_ENABLED = false; inline void WARN(const string &message) { if (!WARNINGS_ENABLED) { return; } // ... }
鉴于构造字符串参数没有副作用,编译器会优化吗?是否需要一定的优化级别?