草庐IT

weakly-referenced

全部标签

c++ - 我是否必须使用 weak_ptr.lock() 来测试它是否指向有效对象?

创建一个临时的shared_ptr只是为了查看weak_ptr是否指向一个有效的对象似乎有点低效。我什至不想访问该对象。这是因为我有一个从shared_ptrvector返回weak_ptr的函数,如果它返回一个空的weak_ptr那么这意味着该对象不存在该GUID。所以我只是在测试一个对象是否存在。有没有另一种方法可以在不创建shared_ptr的情况下检查weak_ptr是否为空? 最佳答案 您可以使用expired()成员函数。 关于c++-我是否必须使用weak_ptr.lock

c++ - 图节点父列表中的 weak_ptr VS shared_ptr

我有一个由Graph和Node类实现的有向无环图。每个节点都有一个指向子节点的指针列表和一个指向父节点的指针列表。我最近添加了父级,因为一些算法需要快速访问父级列表,而且图很小,每个节点只有很少的连接,所以没有内存问题。子列表使用std::shared_ptr以便节点至少在它们有父节点时保留在内存中。但是我不希望节点拥有它的父节点,所以我使用weak_ptr作为指向父节点的指针。但是后来算法出了问题。算法必须从weak_ptr创建一个新的shared_ptr,所以我不能直接使用operator==,并且使用标准函数如std::find()需要编写一个调用my_weak_ptr.lock

c++ - 使用不遵循 'strict weak ordering' 的比较函数对列表进行排序

我有一个包含10个项目的列表。我想以特定方式对它们进行排序。例如。项目是A1,B,C1,A2,A3,F,G,C2,H,A4规则是C应该总是在A之前B应该总是在A之后所有其他项目应保持其顺序。所以排序后列表应该是这样的顺序C1C2A1A2A3FGHA4B我正在尝试使用C++std::stable_sort()方法来实现这一点。在我的程序中,所有项目都是结构“SItem”的实例,它有一个成员“type”来指示其类别(A、B等)。我的比较函数是这样的boolCompareItems(SItemconst&item1,SItemconst&item2){if(item1.type==A&&it

c++ - 最好返回 C++ 引用或 weak_ptr?

假设我有一个类,我希望用户能够在其中引用我的成员之一。哪个更受欢迎?classMember;classClassWithWeakPtr{private:boost::shared_ptr_member;public:boost::weak_ptrGetMember();};或classMember;classClassWithCppReference{private:Member_member;public:Member&GetMember(){return_member;}};你怎么看?什么时候比另一个更好? 最佳答案 为什么不返

c++ - 从原始指针创建 weak_ptr<>

我想将原始指针成员包装到一些智能指针,以防止在开发类中删除。指针下对象的所有者在类之外。所以,看起来像boost::shared_ptr和std::auto_ptr不适合。以下是简化的示例:classFoo{boost::weak_ptrm_bar;public:voidsetBar(constBar*bar){//barcreatedonheapm_bar=bar;//naturallycompilationerror}};当然会导致编译错误。从原始指针(如果存在)初始化weak_ptr的正确方法是什么? 最佳答案 你不能那样做,

c++ - weak_ptr 如何知道共享资源已过期?

考虑以下代码:#include#includeusingnamespacestd;structMySharedStruct{inti;};voidprint_value_of_i(weak_ptrweakPtr){if(shared_ptrsp=weakPtr.lock()){coutisharedPtr(newMySharedStruct());sharedPtr->i=5;weak_ptrweakPtr;weakPtr=sharedPtr;print_value_of_i(weakPtr);sharedPtr.reset(newMySharedStruct());//i=10;pr

c++ - 缺少 shared_ptr 和 weak_ptr 之间的相等性

虽然我明白为什么shared_ptr和unique_ptr没有operator==,但我想知道为什么没有shared_ptr和weak_ptr。特别是因为您可以通过对shared_ptr的引用创建一个weak_ptr。我假设在99%的时间里您都需要lhs.get()==rhs.get()。我现在会继续将其引入我的代码,除非有人能给我一个很好的理由,为什么不应该做这样的事情。 最佳答案 weak_ptr没有get()方法,因为您需要在访问底层指针之前显式锁定weak_ptr。明确这一点是一个深思熟虑的设计决定。如果转换是隐式的,那么很

【C++】C++11——智能指针、内存泄漏、智能指针的使用和原理、RAII、auto_ptr、unique_ptr、shared_ptr、weak_ptr

文章目录C++117.智能指针7.1内存泄漏7.2智能指针的概念7.3智能指针的使用7.3.1auto_ptr7.3.2unique_ptr7.3.3shared_ptr7.3.4weak_ptrC++117.智能指针7.1内存泄漏  什么是内存泄漏:  内存泄漏指因为疏忽或错误造成程序未能释放已经不再使用的内存的情况。内存泄漏并不是指内存在物理上的消失,而是应用程序分配某段内存后,因为设计错误,失去了对该段内存的控制,因而造成了内存的浪费。  内存泄漏通常由于程序在设计上的缺陷或错误,例如动态分配内存后,未在合适的时间或无法正确释放该段内存,而导致的。内存泄漏通常需要程序员通过分析程序源代码

windows - 错误 LNK2019 : unresolved external symbol __CheckForDebuggerJustMyCode referenced in function DriverEntry

我编写了一个Windows10驱动程序。下面是代码,实际上代码是learn.microsoft.com的示例。有没有人知道我应该做什么来处理这个问题。#include#includeDRIVER_INITIALIZEDriverEntry;EVT_WDF_DRIVER_DEVICE_ADDKmdfHelloWorldEvtDeviceAdd;NTSTATUSDriverEntry(_In_PDRIVER_OBJECTDriverObject,_In_PUNICODE_STRINGRegistryPath){//NTSTATUSvariabletorecordsuccessorfailu

“Property or method “***“ is not defined on the instance but referenced during render.”报错的原因及解决方案

报错问题:在使用vue-cli运行项目的过程中,在VScode中不报错,但在浏览器调试工具中发出 [Vuewarn]:Propertyormethod"******"isnotdefinedontheinstancebutreferencedduringrender.Makesurethatthispropertyisreactive,eitherinthedataoption,orforclass-basedcomponents,byinitializingtheproperty.的报错。报错原因:属性或方法“list”未在实例上定义,但在渲染期间被引用。通过初始化该属性,确保该属性是被动的