Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Cekap Membaca Fail menjadi `std::vector` Tanpa Overhed?

Bagaimana untuk Cekap Membaca Fail menjadi `std::vector` Tanpa Overhed?

Susan Sarandon
Susan Sarandonasal
2024-11-11 18:48:03911semak imbas

How to Efficiently Read a File into a `std::vector` Without Overhead?

Pengendalian Fail yang Cekap menjadi Vektor Aksara

Dalam usaha untuk mengoptimumkan bacaan fail menjadi std::vector, pembangun menghadapi cabaran. Kaedah biasa menggunakan rizab dan bacaan seterusnya membawa kepada ralat kerana kekurangan elemen pada indeks 0. Kaedah lain seperti mengubah saiz atau memulakan vektor dengan saiz menanggung overhed yang ingin dielakkan oleh pembangun.

Penyelesaiannya terletak pada penggunaan iterator. Dengan mencipta iterator streambuf input dan menggunakannya untuk membina vektor, kandungan fail boleh terus diberikan kepada vektor tanpa memerlukan salinan perantaraan. Coretan kod berikut menggambarkan pendekatan ini:

#include<iterator>

std::ifstream testFile("testfile", std::ios::binary);
std::vector<char> fileContents((std::istreambuf_iterator<char>(testFile)),
                               std::istreambuf_iterator<char>());

Untuk kebimbangan prestasi, menempah ruang dalam vektor sebelum tugasan boleh menghalang pengagihan semula:

std::vector<char> fileContents;
fileContents.reserve(fileSize);
fileContents.assign(std::istreambuf_iterator<char>(testFile),
                    std::istreambuf_iterator<char>());

Atas ialah kandungan terperinci Bagaimana untuk Cekap Membaca Fail menjadi `std::vector` Tanpa Overhed?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn