什么消耗了更多的存储空间——boost::dynamic_bitset<>还是原始存储?

发布于 2024-11-10 10:34:44 字数 310 浏览 2 评论 0 原文

我有一个程序存储优化问题。

假设我有 4096 个“结”存储在 a:

  boost::dynamic_bitset<>

我现在正在考虑重构我的程序并构建一个包含 boolCKnot 类。

问题是什么会消耗更多空间:

  • boost::dynamic_bitset<> (4096,假);
  • CKnot Knot[4096] //包含一个布尔值

谢谢

I have a program storage optimization question.

I have, let say 4096 "knots" stored in a:

  boost::dynamic_bitset<>

I am now considering refactoring my program and build a CKnot class which will contain a bool.

The question is what will consume more space:

  • boost::dynamic_bitset<> ( 4096 , false );
  • CKnot Knot[4096] //contain one bool

Thanks

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

扬花落满肩 2024-11-17 10:34:44

位集将小得多,因为 C++ 中的 bool 大小必须至少为一个字节,而位集中的每个位正是一个位。

The bitset will be considerably smaller, as a bool in C++ must be at least a byte in size, whereas each bit in a bitset is exactly that, a bit.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文