网上很多说 shared_ptr 靠引用计数实现的。确实,但是我感觉没有说的很明白。举个例子
void f(){
shared_ptr a (new A);
shared_ptr b=a;
}
现在解释下,第一步shared_ptr 对象生成,里面对A对象的引用计数+1,a里面的引用计数成员变量为1,第二步,b=a, b对象生成,b里面的引用计数成员变量为2,那没此时对A对象的应用就变为2了,那现在问题来了,什么时候析构呢,其实这个是作用域的问题,a,b的作用域是f函数,当函数结束时,首先b退出作用域,引用计数-1(b里面存的引用计数为1,此时不释放A),再a退出作用域,a里面的引用计数成员变量由创建是的1减1 ,记住是a本身的引用技术成员变量减-1,不是b里面的减1,此时减为0,在a对象里执行释放A.
所以,对于智能指针的引用计数,其实就是作用域的销毁问题