c – weak_ptr如何知道共享资源已经过期?

考虑以下代码
#include <memory>
#include <iostream>

using namespace std;

struct MySharedStruct
{
  int i;
};

void print_value_of_i(weak_ptr<MySharedStruct> weakPtr)
{
  if (shared_ptr<MySharedStruct> sp = weakPtr.lock())
  { cout << "Value of i = " << sp->i << endl; }
  else
  { cout << "Resource has expired"; }
}

int main()
{
  shared_ptr<MySharedStruct> sharedPtr(new MySharedStruct() );
  sharedPtr->i = 5;

  weak_ptr<MySharedStruct> weakPtr;
  weakPtr = sharedPtr;

  print_value_of_i(weakPtr);

  sharedPtr.reset(new MySharedStruct() ); // <<----- How does weak_ptr kNow it has expired after this line executes?
  sharedPtr->i = 10;

  print_value_of_i(weakPtr);

  return 0;
}

考虑到shared_ptr引用的资源已经被另一个资源所替代,weak_ptr知道它已经过期了吗?什么是weak_ptr跟踪,以确定旧的共享资源被销毁并被新的共享资源所替代?将会感谢在weak_ptr中锁定的方法的示例定义(如果相关).

解决方法

从plain指针创建shared_ptr时分配的控制块包含对象的引用计数器和对象本身的指针以及自定义删除对象(如果有的话).当引用计数器达到零时,对象被释放,指针被设置为null.因此,当对象引用计数器为零时,意味着该对象已经消失.

对于x86和x86-64,它们使用原子操作,没有明确的锁定(无互斥锁或自旋锁).实现的技巧是一个特殊的无锁(忙碌的代码语言)函数atomic_conditional_increment,只有当对象引用计数器不为零时才会递增.当多个线程尝试从相同的weak_ptr创建一个shared_ptr,对象引用计数器为零时,它用于执行weak_ptr :: lock函数来应对比赛.见http://www.boost.org/doc/libs/1_52_0/boost/smart_ptr/detail/sp_counted_base_gcc_x86.hpp

控制块本身在shared_ptr和weak_ptr之间共享,并且具有另一个引用计数器,以使其保持活动,直到最后一次引用它被释放.

当重新分配一个shared_ptr时,它指向另一个控制块,这样控制块只会指向一个相同的对象.换句话说,在控制块中没有替换另一个对象.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...