草庐IT

weak-template-vtables

全部标签

c++ - 'template<class _Tp> struct std::less' 在不同命名空间中的特化

我专门针对数据类型使用“少”(谓词)。代码如下所示:templatestructstd::less{booloperator()(constDateTimeKey&k1,constDateTimeKey&k2)const{//Somecode...}};编译时(Ubuntu9.10上的g++4.4.1),我收到错误:'templatestructstd::less'在不同命名空间的特殊化我做了一些研究,发现有一个“解决方法”涉及将特化包装在std命名空间中-即将代码更改为:namespacestd{templatestructless{booloperator()(constDateT

c++ - weak_ptr 的性能损失是多少?

我目前正在为游戏设计一个对象结构,在我的例子中,最自然的组织变成了一棵树。作为智能指针的忠实粉丝,我只使用shared_ptr的。然而,在这种情况下,树中的子节点需要访问它的父节点(例如——map上的生物需要能够访问map数据——因此他们的父节点的数据。拥有的方向当然是map拥有它的存在,因此持有指向它们的共享指针。然而,为了从一个存在中访问map数据,我们需要一个指向父级的指针——智能指针的方式是使用一个引用,即weak_ptr。但是,我曾经读到锁定weak_ptr是一项昂贵的操作——也许这不再是真的了——但考虑到weak_ptr会经常被锁定,我担心这种设计注定性能不佳。因此问题:锁

c++ - weak_ptr 的性能损失是多少?

我目前正在为游戏设计一个对象结构,在我的例子中,最自然的组织变成了一棵树。作为智能指针的忠实粉丝,我只使用shared_ptr的。然而,在这种情况下,树中的子节点需要访问它的父节点(例如——map上的生物需要能够访问map数据——因此他们的父节点的数据。拥有的方向当然是map拥有它的存在,因此持有指向它们的共享指针。然而,为了从一个存在中访问map数据,我们需要一个指向父级的指针——智能指针的方式是使用一个引用,即weak_ptr。但是,我曾经读到锁定weak_ptr是一项昂贵的操作——也许这不再是真的了——但考虑到weak_ptr会经常被锁定,我担心这种设计注定性能不佳。因此问题:锁

c++ - 等式比较 std::weak_ptr

我想比较两个std::weak_ptr或一个std::weak_ptr和一个std::shared_ptr是否相等。我想知道的是每个weak_ptr/shared_ptr指向的对象是否相同。不仅如果地址不匹配,而且如果底层对象被删除然后偶然用相同的地址重建,则比较应该会产生负面结果。所以基本上,即使分配器保留相同的地址,我也希望这个断言成立:autos1=std::make_shared(43);std::weak_ptrw1(s1);s1.reset();autos2=std::make_shared(41);std::weak_ptrw2(s2);assert(!equals(w1

c++ - 等式比较 std::weak_ptr

我想比较两个std::weak_ptr或一个std::weak_ptr和一个std::shared_ptr是否相等。我想知道的是每个weak_ptr/shared_ptr指向的对象是否相同。不仅如果地址不匹配,而且如果底层对象被删除然后偶然用相同的地址重建,则比较应该会产生负面结果。所以基本上,即使分配器保留相同的地址,我也希望这个断言成立:autos1=std::make_shared(43);std::weak_ptrw1(s1);s1.reset();autos2=std::make_shared(41);std::weak_ptrw2(s2);assert(!equals(w1

c++ - 使用 GDB 打印 C++ vtables

我正在尝试使用gdb打印对象的vtable;我找到了showprintvtblon设置,但我仍然不知道如何打印vtable-p*object仍然不打印出来。如何打印vtable? 最佳答案 更紧凑的解决方案:p/a(*(void***)obj)[0]@10 关于c++-使用GDB打印C++vtables,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6191678/

c++ - 使用 GDB 打印 C++ vtables

我正在尝试使用gdb打印对象的vtable;我找到了showprintvtblon设置,但我仍然不知道如何打印vtable-p*object仍然不打印出来。如何打印vtable? 最佳答案 更紧凑的解决方案:p/a(*(void***)obj)[0]@10 关于c++-使用GDB打印C++vtables,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6191678/

c++ - shared_ptr 和 weak_ptr 失败的小例子

我在使用shared_ptr时遇到问题和weak_ptr连同enable_shared_from_this.当我用谷歌搜索我所看到的症状时,每个人都建议“当没有shared_from_this()实例拥有你的对象时,你不能使用shared_ptr。但这不是我的情况。考虑这段代码:#include#includeclassMyClass:std::enable_shared_from_this{public:voidthis_fails(){//Doesn'tevenassert(),becauseitthrowsbad_weak_ptrassert(shared_from_this()

c++ - shared_ptr 和 weak_ptr 失败的小例子

我在使用shared_ptr时遇到问题和weak_ptr连同enable_shared_from_this.当我用谷歌搜索我所看到的症状时,每个人都建议“当没有shared_from_this()实例拥有你的对象时,你不能使用shared_ptr。但这不是我的情况。考虑这段代码:#include#includeclassMyClass:std::enable_shared_from_this{public:voidthis_fails(){//Doesn'tevenassert(),becauseitthrowsbad_weak_ptrassert(shared_from_this()

c++ - Qt 未定义对 vtable 的引用

这个问题在这里已经有了答案:QtLinkerError:"undefinedreferencetovtable"[duplicate](9个回答)关闭7年前。我是Qt编程的初学者,并且在我的编程中使用代码块。我创建了3个文件c​​ommunicate.h、commmunicate.cpp和main.cpp,如下:communicate.h#ifndefCOMMUNICATE_H#defineCOMMUNICATE_H#include#include#include#includeclassCommunicate:publicQWidget{Q_OBJECTpublic:Communic