gpt4 book ai didi

c++ - 寻找,相对或绝对位置?

转载 作者:行者123 更新时间:2023-11-30 04:16:48 29 4
gpt4 key购买 nike

我需要从文件中读取一个数组。该数组在文件中不是连续排序的,必须跳转“偏移”字节才能获得下一个元素。假设我读取一个非常大的文件,什么更有效率。

1) 使用增量相对位置。
2)使用绝对位置。

选项 1:

int var[N];
seekg(0);
for (int i=0; i<N; i++) {
file.read( (char*) var+i, sizeof(int))
seekg(offset,ios_base::cur);
}

选项 2:

int var[N];
for (int i=0; i<N; i++) {
file.seekg(offset*i);
read( (char*) var+i, sizeof(int))
}

最佳答案

read 已经提前了位置,所以你不需要在循环内寻找。此外,数组在内存中的布局是连续的,因此您可以说:

std::vector<int> var(N);

auto res = file.read(reinterpret_cast<char*>(var.data()), sizeof(int) * var.size());

只需确保随后检查 resfile 的值:

if (!file || res != sizeof(int) * var.size())
{
// an error occurred
}

如果您正在读取文件的随机部分,那么您的查找方式没有任何区别(文件本质上是“随机访问”)。但一定要在每次读取之后运行上述测试以捕获错误。

关于c++ - 寻找,相对或绝对位置?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17505674/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com