如何避免 #includ 借助<sstream>模板功能?
How can I avoid #includ-ing <sstream> thanks to a template function?
我写了一个非常简单的日志记录类。
日志记录类有一个如下所示的函数:
template <typename T, typename... Args>
void log (T && first, Args &&... rest) {
log (std::forward <T> (first));
log (std::forward <Args> (rest)...);
}
template <typename T>
void log (T && last) {
/* use <sstream>'s std::ostringstream to convert each T to its string
representation, then print it via a callback. */
}
由于我的日志记录类可能在整个程序中经常使用,因此我正在尝试减少由于#includ
记录器文件而附加到每个翻译单元上的代码量。
我已经设法将除<string>
之外的所有 #include
语句移出头文件并移入实现文件,除了整个 <sstream>
及其所有依赖项,这是实现此模板成员函数所必需的。
我已经考虑过显式实例化我需要的所有重载,但如果我希望将我的记录器与字符串文字一起使用,那么我想我必须为 const char (&) [n]
中的每个n
显式实例化一个模板。 或者#include <type_traits>
std::decay
. :(
是否可以避免将<sstream>
拖入使用我的记录器的所有 TU? 如何?
在我的项目中,我合并的一种方法是使用 C++11 中的std::to_string()
。这可以避免使用<sstream>
。您可能只需要包含<string>
标头。对于特定的类,可以实现自己的公共方法to_string()
。
但是Android版本(我们一直使用到2016年年中(不幸的是,即使使用C++11也没有std::to_string()
。在这种情况下,我们必须依靠 sstream
.但是,您可以通过使用以下template
和宏技巧(玩具代码(来避免在头文件中包含<sstream>
:
// header.h
template<typename ostringstream, typename T>
std::string my_to_string (T&& value)
{
ostringstream oss;
oss << value;
return oss.str();
}
#define my_to_string(X) my_to_string<std::ostringstream>(X)
现在,在所有实现中,您必须按如下方式<sstream>
和使用:
// implementation.cpp
#include<sstream>
int main ()
{
double d = 1.2345;
std::string s = my_to_string(d);
std::cout << "converted: " << s << "n";
}
演示。
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- EASTL矢量<向量<int>>连续的
- 如何在Directwrite中获得给定字体的可用OpenType功能
- 对可变参数使用声明.如何选择正确的功能
- 询问在设计我的手臂模拟器功能表示格式1
- 功能原型的目的