只要是变量就有大小,其大小就是取决于定义它的类型,那一个智能指针 shared_ptr<T> 类型的变量的大小是多少呢?
#include <stdio.h>
#include <stdlib.h>
#include <memory>
class CTest
{
public:
CTest()
{
printf("constructor\n");
}
~CTest()
{
printf("destructor\n");
}
};
int main()
{
std::shared_ptr<CTest> ptr = std::make_shared<CTest>();
printf("sizeof(ptr) = %lu\n", sizeof(ptr));
return 0;
}
可以看到一个智能指针变量的大小是 16 字节。那为什么是 16 呢?我们可以看源码上看一看。
首先看一下 shared_ptr 的声明:
从GDB中更容易看出它的定义:
可以看到它没有成员数据,但它继承自 __shared_ptr,那它的父类的定义是什么呢?
而在源码中也可以看到这个父类有 2 个成员数据:
_Tp* _M_ptr; 就是指向_Tp 对象的指针,还有一个__shared_count<_Lp> 类型的变量_M_refcount;
而这个类型 __shared_count<_Lp> 也只有一个指针变量。所以一个 shared_ptr 类型的变量包含了 2 个指针,一个指向对象,一个应该是用于管理引用计数。一个指针变量,在64位系统下是占 8 个字节,所以一个shared_ptr 变量在 64 位系统下是 16 字节大小。