电话:0731-83595998
导航

2015年软件水平考试程序员精选题(6)2

来源: 2017-10-20 12:39

  为了防止有多个指针指向的数据被多次删除,我们还可以保存究竟有多少个指针指向该数据。只有当没有任何指针指向该数据的时候才可以被删除。这种思路通常被称之为引用计数技术。在构造函数中,引用计数初始化为1;每当把这个实例赋值给其他实例或者以参数传给其他实例的构造拷贝函数的时候,引用计数加1,因为这意味着又多了一个实例指向它的data;每次需要调用析构函数或者需要把data赋值为其他数据的时候,引用计数要减1,因为这意味着指向它的data的指针少了一个。当引用计数减少到0的时候,data已经没有任何实例指向它了,这个时候就可以安全地删除。实现的代码如下:

  public:

  Array(unsigned arraySize)

  :data(0), size(arraySize), count(new unsigned int)

  {

  *count = 1;

  if(size > 0)

  data = new T[size];

  }

  Array(const Array& copy)

  : size(copy.size), data(copy.data), count(copy.count)

  {

  ++ (*count);

  }

  ~Array()

  {

  Release();

  }

  const Array& operator = (const Array& copy)

  {

  if(data == copy.data)

  return *this;

  Release();

  data = copy.data;

  size = copy.size;

  count = copy.count;

  ++(*count);

  }

  private:

  void Release()

  {

  --(*count);

  if(*count == 0)

  {

  if(data)

  {

  delete []data;

  data = NULL;

  }

  delete count;

  count = 0;

  }

  }

  unsigned int *count;

编辑推荐:

下载Word文档

温馨提示:因考试政策、内容不断变化与调整,长理培训网站提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准! (责任编辑:长理培训)

网络课程 新人注册送三重礼

已有 22658 名学员学习以下课程通过考试

网友评论(共0条评论)

请自觉遵守互联网相关政策法规,评论内容只代表网友观点!

最新评论

点击加载更多评论>>

精品课程

更多
10781人学习

免费试听更多

相关推荐
图书更多+
  • 电网书籍
  • 财会书籍
  • 其它工学书籍
拼团课程更多+
  • 电气拼团课程
  • 财会拼团课程
  • 其它工学拼团
热门排行

长理培训客户端 资讯,试题,视频一手掌握

去 App Store 免费下载 iOS 客户端