大きなファイルを書き込もうとしていますが、問題が発生しました。C++で4GBを超えるファイルにデータを書き込む方法は?
書き込む場所を探すのに長いロングを使用しますが、4,2Gbを超えるファイルは書き込めません。私が忘れたのは何ですか?
詳細: 私は4GBのファイル開く:その後
ifstream ifs(db_name.c_str(), ios_base::binary);
if (!ifs)
throw Bad_archive();
ifs.read(as_bytes(seg_size), sizeof(int));
ifs.read(as_bytes(last_idx), sizeof(int));
ifs.read(as_bytes(free_segs), sizeof(int));
if (free_segs > 0)
{
long long seek_g = 3 * sizeof(int) + (long long)last_idx * seg_size;
ifs.seekg(seek_g, ios_base::beg);
for (int i = 0; i < free_segs; i++)
{
int tmp = 0;
ifs.read(as_bytes(tmp), sizeof(int));
free_spaces.push_back(tmp);
}
}
ifs.close();
は、私は、DBに追加する最大400Mbファイルを読み込みます。 (ここでは短いコードがある)書き込み:その後
// write object
ofstream ofs(db_name.c_str(), ios_base::binary | ios_base::in | ios_base::ate);
for (int i = 0; ; i++)
{
// set stream position
long long write_position = sizeof(int) * 3;
...
write_position += (long long) seg_size * last_idx;
ofs.seekp(write_position, ios::beg);
...
// write sizeof object
if (i == 0)
ofs.write(as_bytes(object_size), sizeof(object_size));
else
{
int null = 0;
ofs.write(as_bytes(null), sizeof(null));
}
// write data
for (int j = 0; j < (seg_size - sizeof(int) * 2); j++)
{
ofs.write(as_bytes(obj_content[j + i * (seg_size - sizeof(int) * 2)]),
sizeof(char));
}
if (write_new_seg)
last_idx++;
...
ofs.write(as_bytes(cont_seg), sizeof(cont_seg));
}
ofs.close();
を、私はDBの情報を保存します
if (last_idx == 0)
{
ofstream ofs(db_name.c_str());
ofs.close();
}
ofstream ofs(db_name.c_str(), ios_base::binary | ios_base::in |
ios_base::out | ios_base::ate);
long long seek_p = 0;
ofs.seekp(seek_p, ios_base::beg);
ofs.write(as_bytes(seg_size), sizeof(seg_size));
ofs.write(as_bytes(last_idx), sizeof(last_idx));
ofs.write(as_bytes(free_segs), sizeof(free_segs));
ofs.close();
をしかし、このコードは動作します:
ofstream ofs2("huge2");
ofs2.close();
ofstream ofs("huge2", ios_base::in | ios_base::ate);
long long sp = 10000000000;
ofs.seekp(10000000000, ios_base::beg);
ofs.write(as_bytes(sp), sizeof(sp));
ofs.close();
ループ内で常にシークして、目的のポイントに進むことはできますが、位置合わせされていないオフセットを追跡することは難しくなります。 –
私はお試しください。 Thanx – bluebyte
多くのC++ストリームの実装は、これまでの世紀に止まっています。誰もが4ギガバイトで十分でした。 64フィンガーでカウントするchar_traits :: pos_typeを更新するのは簡単ではなく、既存のコードを破壊します。 intについて語ったupvoted答えはそれを明白にします。 –