提振.轻量级内存消耗
Boost.Flyweight memory consumption
我正在读一篇关于Boost的文章。轻量级选手表演
从链接中可以看到,工厂的开销是
- for hashed_factory
: ~2.5 * sizeof(word)
- for set_factory
: 4 * sizeof(word)
基本问题是....为什么4个单词表示set而不是0
据我所知,使用哈希意味着计算和存储哈希键,而使用set not:它被实现为红黑树,插入和查找需要log(n),所以没有存储值,内存开销应该为零(缺点是,在哈希的情况下,不是一次比较,而是有log(n)次比较)。
RB树的每个节点包含一个指向左子节点的指针、一个指向右子节点的指针、颜色和一段数据。前三个被算作开销,这意味着它不为0。我不太确定为什么他们说这是4,当3个元素很容易适合3个词,但也许他们计数在其他东西(如父节点指针,这不是严格必要的,或内存分配开销,虽然这是不太可能的)。
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- linux上的轻量级内存泄漏调试
- 提振.轻量级内存消耗