编译时与使用boost::fusion的运行时
compile time vs run time with boost::fusion
我对Boost融合很陌生,也许我的问题没有任何意义。融合被描述为:"运行时和编译时算法之间的融合"。我想我在编译时所做的和运行时在融合中所做的之间迷失了方向。
让我们取for_each
模板,事实上它们是两个!函数和元函数。元函数在我看来像是for_each
函数的特征类模板,错了吗。
以for_each
函数为例
struct increment
{
template<typename T>
void operator()(T& t) const
{
++t;
}
};
vector<int,int> vec(1,2);
for_each(vec, increment());
我知道for_each
循环将在编译时展开,以生成类似的代码
++at_c<0>(vec);
++at_c<1>(vec);
(显然,at_c<x>
模板也将生成访问融合向量成员的代码)
对我来说,for_each函数和metafunction都是"编译时程序",又错了吗
有人能解释一下(举一个简单的例子)boost融合的哪一部分只是编译时元程序,什么只是经典编译时代码吗?
boost::fusion是关于操作类型的异构集合。在C++中,类型的处理在编译时处理(元函数),而值操作主要在运行时处理(函数)。
如果你仔细查看boost::fusion中的文档,你会发现元函数返回了…:类型这些类型必须在编译时处理。
在C++中,有一些类似RTTI(运行时类型信息)的东西,但在大多数情况下,它的能力被降级为在运行时识别某种东西的类型。运行时没有可用的类型操作。
因此,必须在编译时处理类型操作。强制编程构造在编译时并不有用。C++编译时构造更类似于函数式编程构造。我花了很长的时间来说明boost::fusion::for_each是一种在编译时展开循环的算法,这样序列中的所有类型在编译时都可以"以线性方式"可见。
然后,每个类型的值在运行时都是对该类型的取消引用。
因此,在整个循环中,boost::fusion::for_each函数提供了值,boost::fusion::for_ech元函数返回一个类型,这对于通过函数间接获得相关值可能很有用。
- CMake-按正确顺序将项目与C运行时对象文件链接
- 我在c++代码中生成了一个运行时#3异常
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 删除指向指针的指针是运行时错误吗
- 如何用参数值调用函数(仅在运行时已知)
- 为什么即使使用-cudart-static进行编译,库用户仍然需要链接到cuda运行时
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- c++中的指针和运行时错误
- 在运行时处理类型擦除的数据-如何不重新发明轮子
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 建议在运行时将带有类实例的列表从c++导入qml
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 如何在GTK程序运行时禁用屏幕保护程序/电源管理/屏幕消隐
- 在同一模拟中使用静脉和静脉_ inet内容时出现运行时错误
- 读取文件时运行时的未知行为
- 如何在运行时填充Boost :: Fusion ::向量
- 如何在运行时在boost::fusion::vector中查找元素
- 编译时与使用boost::fusion的运行时
- Boost.Fusion运行时开关
- 无法运行使用 macdeployqt 创建的 OSX 应用程序。使用 Fusion 样式时缺少可可插件