- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
(42);"的定义?-6ren"> (42);"的定义?-为什么weak.lock()返回 nullptr在此代码片段中: std::weak_ptr weakPtr1 = std::make_shared(6); std::cout shar-6ren">
为什么weak.lock()
返回 nullptr
在此代码片段中:
std::weak_ptr<int> weakPtr1 = std::make_shared<int>(6);
std::cout << weakPtr1.lock() << std::endl;
std::shared_ptr<int> sharedPtr = std::make_shared<int>(99);
std::weak_ptr<int> weakPtr2 = sharedPtr;
std::cout << weakPtr2.lock() << std::endl;
最佳答案
智能指针,为了正常工作,维护一个所谓的控制块,作为元数据存储,特别是使用计数器。也就是说,每个资源在内存中都有一个关联的控制块(由例如两个整数组成),智能指针可以引用它来了解它们中有多少仍在使用/观察资源。显然,每个存在std::shared_ptr
增加存储在控制块中的使用计数器,以便其析构函数知道是否是在销毁时释放资源的时间。 std::weak_ptr
,反过来,只跟踪对象及其控制块。请注意,这里有一个重要的细节:std::weak_ptr
不增加使用计数器。这是可取的,因为它的主要目的是打破一对相互观察的对象之间可能的循环。也就是说,如果两个对象将存储 std::shared_ptr
一个对一个,那么这样一对对象也将永生不息。
怎么可以std::weak_ptr
知道资源是否可以lock()
编辑?只有当使用计数器大于零时,这才能成功。它从控制块(它本身在内存中保持事件状态,只要还有非零弱指针观察它)就知道了。
在第一个例子中:
std::weak_ptr<int> weakPtr1 = std::make_shared<int>(6);
int=6
)及其控制块。使用计数器变为
1
,并且只要
std::shared_ptr
就保持不变活着。然后,一个
std::weak_ptr
被初始化,获得一个指向控制块的指针。在这里,它不会增加使用计数器。然而,它会增加弱指针的计数器。此时,两个计数器都是
1
.然后,在分号
;
,临时
std::shared_ptr
被摧毁。它将使用计数器减少到
0
.这意味着不再有共享资源的所有权的共享指针,这允许释放该资源。但是,还有
1
弱指针观察控制块,这意味着控制块本身会留在内存中,所以
weakPtr1
知道它不能
lock()
资源(因为该资源不再存在)。
std::shared_ptr<int> sharedPtr = std::make_shared<int>(99);
std::weak_ptr<int> weakPtr2 = sharedPtr;
int=99
并且它的控制块保持事件状态。因此
weakPtr2
只要
sharedPtr
即可锁定(或其任何拷贝)不会被销毁。
关于c++ - 为什么 "weak.lock()"返回 "nullptr"与 "auto weak=std::make_shared<int>(42);"的定义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62401405/
我正在尝试为我的学校作业制作信息亭程序。当我编译它时,它不会发出任何错误信号。但是当我尝试初始化我的队列列表时,它说我不能使用 nullptr...我不明白我的代码有什么问题。 typedef str
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题吗? 更新问题,以便 editing this post 提供事实和引用来回答它. 关闭 4 年前。 Improve
这个问题在这里已经有了答案: Placement of the asterisk in pointer declarations (14 个答案) 关闭 4 年前。 在博客和论坛上,我注意到人们使用
为什么std::string str(nullptr)和 std::string str=nullptr是错的?有人可以详细解释原因吗? 最佳答案 这样的例子编译是因为存在一个 std::string
这个定义有效: const auto &b{nullptr}; 虽然失败: auto *b{nullptr}; 我尝试在 Visual C++、GCC 和 Clang 中编译它。他们都提示“无法推断类
刚刚看了一篇关于C++0x标准的文章:http://www.softwarequalityconnection.com/2011/06/the-biggest-changes-in-c11-and-w
我已将节点指针初始化为 nullptr 并将其作为引用传递给辅助函数。在辅助函数内,我将之前为 nullptr 的指针设置为等于 new Pointer。然而,函数结束后,它又被设置为nullptr。
有谁知道为什么分配type* = 0无效,而分配type* = nullptr无效呢?在这两种情况下typedef void type。谢谢 #include #include template
我正在尝试为类(class)项目创建链表。我的节点类有一个指向链接节点的指针和另一个指向专门书籍类的指针。 class Node{ private: Book *data; Node
我在destroyStudent()函数中删除指针aStudent,然后我将aStudent设置为空指针。但是,运行该函数后,aStudent 不再设置为nullptr,所以我必须再次将其设置为nul
我正在尝试制作一个基本的 HashMap。在将元素插入索引之前,我正在检查它是否存在于索引中。当我插入第一个元素时,它说该位置已经存在一个元素。我已经通过调试器,我的所有值都符合预期,map[hash
我正在尝试做类似的事情: if (foo) return SET_ERROR_AND_RETURN_NULL(ERROR_HERE); 使用... #define SET_ERROR_AND
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 6 年前。 Improve
我有一个看起来像这样的结构: struct Wolf { Wolf *dog; Wolf *puppy; }; 我写过: Wolf *alphawolf = new Wolf; 当我尝
我正在使用带有 Visual Studio 2012 的 C++(11)。 我使用定制的包装器类创建窗口。 CUIWindow* winA = new CUIWindow ( NULL, TEXT("
我为它编写了一个 PriorityQueue 类和一个迭代器类。但我不明白为什么这些行编译? PriorityQueue pq; auto z =pq.begin(); z=nullptr
我正在学习 enable_if 的用法我偶然发现了以下代码。 template ::value, T>::type* = nullpt
我有一个函数func(int a, char b, void *ptr)。第三个参数保留供内部使用,它应该是当前版本的 nullptr。有没有办法在函数原型(prototype)而不是定义中强制执行此
所以当我在学校编译它时 nullptr 错误没有出现,我想我可以通过在编译时添加一行来修复它,有没有另一种方法来摆脱它,另外两个错误我不明白为什么我要得到它们。有人可以至少解释一下 nullptr 错
这个问题在这里已经有了答案: Checking if this is null (8 个答案) 关闭 4 年前。 我想像这样替换代码: if ((obj != nullptr) && obj->is
我是一名优秀的程序员,十分优秀!