>  기사  >  백엔드 개발  >  바이너리 파일을 부호 없는 문자 벡터로 읽는 것을 최적화하는 방법은 무엇입니까?

바이너리 파일을 부호 없는 문자 벡터로 읽는 것을 최적화하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-02 03:37:02213검색

How to Optimize Reading Binary Files into a Vector of Unsigned Chars?

바이너리 파일 읽기 최적화

바이너리 파일을 부호 없는 문자 벡터로 최적으로 읽으려면 다음 전략을 고려하십시오.

방법 1: 사용자 정의 벡터 생성

<code class="cpp">std::vector<BYTE> readFile(const char* filename)
{
    std::ifstream file(filename, std::ios::binary);
    std::streampos fileSize = file.tellg();
    file.seekg(0, std::ios::beg);
    std::vector<BYTE> fileData(fileSize);
    file.read((char*) &fileData[0], fileSize);
    return fileData;
}</code>

이 방법은 파일 크기에 따라 올바른 크기의 벡터를 명시적으로 생성합니다. 그러나 벡터의 데이터를 char*로 캐스팅하는 것은 바람직하지 않습니다.

방법 2: Istreambuf Iterator

<code class="cpp">std::vector<BYTE> readFile(const char* filename)
{
    std::ifstream file(filename, std::ios::binary);
    return std::vector<BYTE>((std::istreambuf_iterator<char>(file)),
                              std::istreambuf_iterator<char>());
}</code>

이 방법은 데이터를 char*로 읽는 반복자를 사용합니다. 내부적으로 char 버퍼. 더 짧기는 하지만 서명되지 않은 문자를 읽더라도 여전히 문자 반복자가 필요합니다.

방법 3: 기본 Ifstream 특수화

<code class="cpp">std::vector<BYTE> readFile(const char* filename)
{
    std::basic_ifstream<BYTE> file(filename, std::ios::binary);
    return std::vector<BYTE>((std::istreambuf_iterator<BYTE>(file)),
                              std::istreambuf_iterator<BYTE>());
}</code>

이 방법은 특수한 입력 파일 스트림을 사용합니다. 서명되지 않은 문자의 경우. 그러나 모든 경우에 적합하지는 않습니다.

최적화

  • 용량 예약: 벡터에 메모리를 사전 할당하면 성능이 향상됩니다.
  • 줄바꿈 억제 비활성화: 바이너리 모드의 ios::skipws는 성능 문제를 일으킬 수 있습니다. unsetf로 비활성화하세요.
  • istream_iterator와 std::copy: std::copy는 >> 연산자와 관련된 오버헤드를 피할 수 있습니다.

고려사항

  • Istreambuf 반복자는 단순성 때문에 선호될 수 있지만 사용자 정의 반복자는 더 나은 성능을 제공할 수 있습니다.
  • "최상의" 방법은 특정 요구 사항에 따라 다릅니다. 애플리케이션과 읽고 있는 데이터.

위 내용은 바이너리 파일을 부호 없는 문자 벡터로 읽는 것을 최적화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.