首页 > 垃圾回收 > 如何用C++来建立自己的垃圾回收机制
2020
03-30

如何用C++来建立自己的垃圾回收机制

  可选中1个或多个下面的关键词,搜索相关资料。也可直接点“搜索资料”搜索整个问题。

  知道合伙人软件行家采纳数:33356获赞数:37431从事多年系统运维,喜欢编写各种小程序和脚本。

  由于C++是一种功能丰富强大的语言,因此有许多不同的方法可以建立垃圾回收器。一个明显但受限制的方法就是基于建立一个垃圾回收器,想要使用垃圾回收的类可以从这个类继承。这样做可以使得一个类接一个类地实现垃圾回收。但遗憾的是,这种方案太有限而不能令人满意!

  更好的解决方案是建立一个可以被任何动态分配的对象使用的垃圾回收器。为了提供这种解决方案,垃圾回收器必须满足以下要求:

  不要破坏任何预先存在的代码。更重要的是,不应该对现有的代码造成任何影响;

  总之,垃圾回收系统必须非常接近C++已经使用的机制和语法来动态分配内存,并且不能响应现有的代码。咋看上去,这好像是一个令人生畏的任务,但是事实并非如此。

  在建立垃圾回收器的时候,面临的关键问题是如何知道某一块内存不再使用。为了理解这个问题,考虑下面的序列:

  在此动态分配了两个int对象。第一个对象包含的值为99,指向这个指针存储在p中。然后,分配了一个值为100的整型数据,其地址也存储在p中,从而改写了第一个地址。在此改写了第一个地址。在此,p(或者其他对象)不再指向int(99)的那块内存,从而可以释放这个内存。问题是,垃圾回收器如何知道p或者其他的对象都不指向int(99)了呢?


本文》有 0 条评论

留下一个回复