- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个这样定义的哈希表
typedef std::unordered_map<unsigned long long int,unsigned long long int> table_map;
在程序中,我使用 fread 将文件的内容读入缓冲区,如下所示:
fread(buffer, sizeof(long long int), 1024, file1);
我将哈希表声明为
table_map c1;
现在我创建一个哈希表,如下所示
for (i = 0; i < 1024; i++)
c1.insert(table_map::value_type(buffer[i], i));
现在我的问题是,在 for 循环之后我怎样才能得到哈希表的大小?
它有 1024 个 unsigned long long int 类型的元素和相同类型的键,但我不能使用 sizeof(Mymap)
或 `size of(c1) 因为它只是返回值32.有什么办法可以找到吗?
谢谢,苏尼尔
最佳答案
将容器的大小属性乘以一对的大小:
std::cout << c1.size() * sizeof(table_map::value_type) << "\n";
在我的系统上,打印出:
16384
这并不完全准确,因为没有考虑簿记数据。您无法解释它,因为(据我所知)该标准对该实现细节没有任何保证。
如果您检查存储桶数据,您可能会得到更好的数据。::bucket,::bucket_count,::bucket_size。不过,这可能只会为您提供有关键、值和对的数据。我没试过。
关于c++ - 如何找到哈希表的大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3562086/
例如,我有一个父类Author: class Author { String name static hasMany = [ fiction: Book,
代码如下: dojo.query(subNav.navClass).forEach(function(node, index, arr){ if(dojo.style(node, 'd
我有一个带有 Id 和姓名的学生表和一个带有 Id 和 friend Id 的 Friends 表。我想加入这两个表并找到学生的 friend 。 例如,Ashley 的 friend 是 Saman
我通过互联网浏览,但仍未找到问题的答案。应该很容易: class Parent { String name Child child } 当我有一个 child 对象时,如何获得它的 paren
我正在尝试创建一个以 Firebase 作为我的后端的社交应用。现在我正面临如何(在哪里?)找到 friend 功能的问题。 我有每个用户的邮件地址。 我可以访问用户的电话也预订。 在传统的后端中,我
我主要想澄清以下几点: 1。有人告诉我,在 iOS 5 及以下版本中,如果您使用 Game Center 设置多人游戏,则“查找 Facebook 好友”(如与好友争夺战)的功能不是内置的,因此您需要
关于redis docker镜像ENTRYPOINT脚本 docker-entrypoint.sh : #!/bin/sh set -e # first arg is `-f` or `--some-
我是一名优秀的程序员,十分优秀!