草庐IT

c++ - 模板对象的类访问者模式

我正在尝试制作一个用于学术目的的自定义碰撞引擎,但我被困在一个通用的C++编程问题上我已经拥有所有可以正常工作的几何形状,并且对于问题的范围,我有这个功能:templateboolintersects(constlhs_geometry&lhs,constrhs_geometry&rhs){//returnstrueifdoesobjectsintersects//(assumethisfunctionsworksperfectlywitheverygeometrytype)}我还需要完成以下类templateclasscollidable_object{public:explicit

c++ - 如何在树访问者中进行每个节点缓存

我有一个应用程序,想要计算通过bool运算(内部节点)组合的图元树(叶节点)的不同表示(网格、体素化、带符号距离函数...)。我的第一个方法是为每个不同的表示编写一个带有虚拟getter函数的抽象基类,并在各自的节点缓存中间结果,只要它们的子树没有变化(这会刷新它们缓存)。但是,我对树结构与每个不同表示的丑陋耦合不满意。为了缓解这种情况,我删除了抽象基类,而是为每个表示设置了一个访问者。这巧妙地将树与表示分离,但给我留下了一个问题,我现在需要在其他地方缓存中间结果,这就是我的问题开始的地方。长话短说如何在树的内部节点缓存(任意多种不同类型的)中间值而不使树依赖于值类型?我的方法需求提供

c++ - 使用 boost::bind 和重载函数的访问者模式

我正在尝试将访问者模式添加到我的代码中,并希望尽可能保持通用。更具体地说,我不想将回调函数硬编码到我的accept函数中。因此,作为accept函数的参数,我给出了一个boost::function对象,然后由访问的对象调用它。然而,我的问题是我无法绑定(bind)到重载函数(因为boost::bind不知道要绑定(bind)到哪个确切的函数)并且我无法将重载函数转换为正确的函数,因为我不知道访问类的确切类型(这很重要)。有什么方法可以创造我想要的东西吗?我搜索了SO,但只发现了有关如何解决绑定(bind)问题的问题(这是通过转换,这是我做不到的)。下面是一些无法编译的代码,但显示了我

c++ - 从访问者更改 boost::variant 基础类型

我有一个模拟S表达式的递归变体:structsexpr{typedefboost::variant>>node_type;node_typenode;};我希望空列表始终由nil表示(不是list)。但是,我坚持执行push_back()访问者。当基础类型为nil时,我希望它将该类型更改为list并推回提供的值:structpush_back_visitor:publicboost::static_visitor{push_back_visitor(constsexpr&arg):arg_(arg){}templatevoidoperator()(constT&value)const{

c++ - 持有大量共享状态的访问者类 : best way to implement reference semantics?

这个问题大致基于使用Visitor的Boost.Graph库(BGL)-like模式来定制递归(搜索)算法。BGL按值传递访问者对象(类似于STL函数对象)和documentation州Sincethevisitorparameterispassedbyvalue,ifyourvisitorcontainsstatethenanychangestothestateduringthealgorithmwillbemadetoacopyofthevisitorobject,notthevisitorobjectpassedin.Thereforeyoumaywantthevisitorto

c++ - C++ 中的通用访问者基类模板 - 重载问题

我认为编写通用访问者基类模板会是一个简单的练习。目标是能够写typedefvisitormy_visitor;...然后让my_visitor成为功能上等同于的类型structmy_visitor{virtualvoidvisit(some_base&){}virtualvoidvisit(some_derived1&){}virtualvoidvisit(some_derived2&){}};我可以继承该类型层次结构的实际有用的派生访问者类,它根据需要覆盖不同的visit()版本。我希望它适用于具有任何继承关系的任意数量的类型,并且我不想使用任何使用type_info比较重新实现虚函

c++ - 如何通过 AST 为访问者模式解决 C++ 中的 header 重复问题

请注意:这些是描述一般困境的代码片段。完整的代码确实包括“includeguards”/#pragmaonce/whathaveyou。我正在实现遍历AST的访问者模式,想知道解决以下问题的C++方法是什么:我有AST.h,它有基本的AST节点类声明:classNode{public:virtualvoidaccept(Visitor*v){v->visit(this);}};连同用于声明、表达式等的所有具体节点子类。然后我有ASTVisitor.h声明访问者界面,按照以下行:classVisitor{public:Visitor(){}virtual~Visitor(){}virtu

c++ - 如何概括具有变体/访问者的树结构

这是我问题的第2部分,最初发布于here.感谢@sehe的澄清和帮助。我最终得到了下面的代码,但我不知道如何将它简化为具有变体和访问者的通用解决方案。非常感谢帮助/建议。谢谢。#include"stdafx.h"#include#include#include#include#include#includetemplateclassA{public:typenameTL;typenamestd::shared_ptrLptr;usingtlist=std::vector>;A(std::stringn=""):_n(n){}A(constA&another):_n(another._n

c++ - Boost 图形库和访问者

我正在编写一个用于处理键合图的库,并且我正在使用BoostGraphLibrary为我存储数据。不幸的是,我似乎无法弄清楚如何使用它来实现适当的访问者模式,因为您不能子类化顶点-您必须依赖“属性”。库中提供的访问者框架似乎非常适合使用某些算法,其中顶点都是同一类型,但存储不同的信息。在我的问题中,顶点具有不同类型并存储不同类型的信息-一些顶点是电阻器,而一些是电容器等。我如何着手编写基于顶点属性而不是工作的访问者模式顶点本身?到目前为止,我唯一的想法是编写一个小类来表示指向我获取图形信息所需的原始顶点的对象的类型。然而,这看起来很笨拙,而且不好用。 最佳答案

c++ - 具有 lambda 的多态访问者

我想在不实现类的情况下使用lambda实现多态访问者。我已经有了一定的基础,但正在为我的lambda表达式的参数进行类型推导而苦苦挣扎。假设我有一些遗留代码库,它决定像这样对多态类型使用类型标签:enumclassClassType{BaseType=0,TypeA,TypeB};classBaseType{public:virtual~BaseType(){}ClassTypegetType()const{returntype;}protected:ClassTypetype;};classTypeA:publicBaseType{public:staticconstClassTyp