gpt4 book ai didi

c - 在 C 中寻找过去 2GiB 的最佳方法是什么?

转载 作者:太空狗 更新时间:2023-10-29 15:07:55 25 4
gpt4 key购买 nike

在C中似乎有很多不同的求道方式:

  • fseek()
  • fsetpos()
  • fseeko()
  • lseek()

而且很多似乎都有 *64() 版本:

  • fseeko64()
  • lseek64()

更复杂的是,许多似乎需要宏定义(如 _LARGEFILE64_SOURCE_GNU_SOURCE)可用或使用 64 位版本。

在 Windows、Linux、Mac、BSD、Solaris 等平台上使用 ANSI C 保证 64 位 IO 的最简单方法是什么?从什么时候开始每个操作系统都支持它?

最佳答案

代码作品需要至少采用以下限制之一:

  1. long 是 64 位+,然后使用 fseek()

  2. 仅查找代码之前由于 fread()、fgets()、fscanf()、fgets() 而到达的位置,因此使用 fgetpos (), fsetpos()。如果文件是文本文件,这是最好的方法。

  3. 可以访问依赖于平台的 64 位搜索,例如 lseek64()

  4. 多个 32 位 fseek()

  5. rewind()fgetc()/fread() 中使用非常低效的代码。

关于c - 在 C 中寻找过去 2GiB 的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34388466/

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