C++ 标准库和 Boehm 垃圾收集器

2024-10-17 08:47:00
admin
原创
184
摘要:问题描述:我想在 Linux/AMD64/Debian 上使用 GCC 4.6(可能是最新的 C++11 标准)开发一个多线程 C++ 应用程序(其中最终大多数 C++ 代码将由应用程序本身生成,可以看作是一种高级领域特定语言)。我确实希望在所有堆分配中使用Boehm 的保守垃圾收集器,因为我想分配new(G...

问题描述:

我想在 Linux/AMD64/Debian 上使用 GCC 4.6(可能是最新的 C++11 标准)开发一个多线程 C++ 应用程序(其中最终大多数 C++ 代码将由应用程序本身生成,可以看作是一种高级领域特定语言)。

我确实希望在所有堆分配中使用Boehm 的保守垃圾收集器,因为我想分配new(GC),而不必担心delete。我假设 Boehm 的 GC 运行良好。

使用 C++(而不是 C)的主要动机是C++ 标准库提供的所有算法和集合std::map...。std::vector

Boehm 的 GC 提供了一个gc_allocator<T>模板(在其文件 gc/gc_allocator.h 中)。

我应该重新定义operator ::new为 Boehm 的吗?

或者我应该使用所有集合模板并将显式分配器模板参数设置为某些gc_allocator?我不明白第二个模板参数(分配器)对std::vector的作用是什么?它是用来分配向量内部数据,还是用来分配每个单独的元素?

那么std::string-s 呢?如何让它们的数据basic_string由 GC 分配?我应该使用带有 的模板来拥有自己的字符串吗gc_allocator?有没有办法让内部的 char 数组由 分配而GC_malloc_atomic不是GC_malloc

或者您建议不要在由 g++ 编译的应用程序中使用 Boehm GC?

问候。


解决方案 1:

为了部分回答我自己的问题,以下代码

// file myvec.cc
#include <gc/gc.h>
#include <gc/gc_cpp.h>
#include <gc/gc_allocator.h>
#include <vector>

class Myvec {
  std::vector<int,gc_allocator<int> > _vec;
public:
  Myvec(size_t sz=0) : _vec(sz) {};
  Myvec(const Myvec& v) : _vec(v._vec) {};
  const Myvec& operator=(const Myvec &rhs) 
    { if (this != &rhs) _vec = rhs._vec; return *this; };
  void resize (size_t sz=0) { _vec.resize(sz); };
  int& operator [] (size_t ix) { return _vec[ix];};
  const int& operator [] (size_t ix) const { return _vec[ix]; };
  ~Myvec () {};
};

extern "C" Myvec* myvec_make(size_t sz=0) { return new(GC) Myvec(sz); }
extern "C" void myvec_resize(Myvec*vec, size_t sz) { vec->resize(sz); }
extern "C" int myvec_get(Myvec*vec, size_t ix) { return (*vec)[ix]; }
extern "C" void myvec_put(Myvec*vec, size_t ix, int v) { (*vec)[ix] = v; }

使用以下方式编译时g++ -O3 -Wall -c myvec.cc生成目标文件:

 % nm -C myvec.o
                 U GC_free
                 U GC_malloc
                 U GC_malloc_atomic
                 U _Unwind_Resume
0000000000000000 W std::vector<int, gc_allocator<int> >::_M_fill_insert(__gnu_cxx::__normal_iterator<int*, std::vector<int, gc_allocator<int> > >, unsigned long, int const&)
                 U std::__throw_length_error(char const*)
                 U __gxx_personality_v0
                 U memmove
00000000000000b0 T myvec_get
0000000000000000 T myvec_make
00000000000000c0 T myvec_put
00000000000000d0 T myvec_resize

::operator new因此,生成的代码中没有普通的 malloc 。

因此,通过使用gc_allocatorand,new(GC)我显然可以确保在我不知情的情况下不会使用普通的::opertor newor malloc,而且我不需要重新定义::operator new


附录(2017 年 1 月)

供将来参考(感谢 Sergey Zubkov 在Quora 的评论中提到它),另请参阅n2670和<memory>垃圾收集支持(如std::declare_reachable、std::declare_no_pointers、std::pointer_safety等...)。但是,至少在当前的 GCC 或 Clang 中尚未实现(除了以简单但可接受的方式使其成为无操作)。

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1142  
  IPD(Integrated Product Development,集成产品开发)流程是一种广泛应用于高科技和制造业的产品开发方法论。它通过跨职能团队的紧密协作,将产品开发周期缩短,同时提高产品质量和市场成功率。在IPD流程中,CDCP(Concept Decision Checkpoint,概念决策检查点)是一个关...
IPD培训课程   96  
  研发IPD(集成产品开发)流程作为一种系统化的产品开发方法,已经在许多行业中得到广泛应用。它不仅能够提升产品开发的效率和质量,还能够通过优化流程和资源分配,显著提高客户满意度。客户满意度是企业长期成功的关键因素之一,而IPD流程通过其独特的结构和机制,能够确保产品从概念到市场交付的每个环节都围绕客户需求展开。本文将深入...
IPD流程   87  
  IPD(Integrated Product Development,集成产品开发)流程是一种以跨职能团队协作为核心的产品开发方法,旨在通过优化资源分配、提高沟通效率以及减少返工,从而缩短项目周期并提升产品质量。随着企业对产品上市速度的要求越来越高,IPD流程的应用价值愈发凸显。通过整合产品开发过程中的各个环节,IPD...
IPD项目管理咨询   95  
  跨部门沟通是企业运营中不可或缺的一环,尤其在复杂的产品开发过程中,不同部门之间的协作效率直接影响项目的成败。集成产品开发(IPD)作为一种系统化的项目管理方法,旨在通过优化流程和增强团队协作来提升产品开发的效率和质量。然而,跨部门沟通的复杂性往往成为IPD实施中的一大挑战。部门之间的目标差异、信息不对称以及沟通渠道不畅...
IPD是什么意思   92  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用