stat64在64位ubuntu上返回32位st_size

时间:2011-02-21 22:41:39

标签: c++ linux

unsigned char *map_file(char *filename, uint64_t *len) {
uint64_t fd = open64(filename, O_RDONLY);

struct stat64 st;
fstat64(fd, &st)

unsigned char *map;
map = (unsigned char *)mmap64(0, st.st_size, PROT_READ, MAP_SHARED, fd, 0);

st.st_size最终为大文件4294967295(我正在测试8.7gb文件)并导致分段错误(47%)。机器是64位,OS(ubuntu)是64位。我做错了什么?

3 个答案:

答案 0 :(得分:3)

您可能需要定义其中一个宏。

http://www.kernel.org/doc/man-pages/online/pages/man7/feature_test_macros.7.html

  _LARGEFILE64_SOURCE
          Expose definitions for the alternative API specified by the LFS (Large
          File Summit) as a "transitional extension" to the Single UNIX
          Specification.  (See http://opengroup.org/platform/lfs.html.)  The
          alternative API consists of a set of new objects (i.e., functions and
          types) whose names are suffixed with "64" (e.g., off64_t versus off_t,
          lseek64() versus lseek(), etc.).  New programs should not employ this
          interface; instead _FILE_OFFSET_BITS=64 should be employed.

  _FILE_OFFSET_BITS
          Defining this macro with the value 64 automatically converts references
          to 32-bit functions and data types related to file I/O and file system
          operations into references to their 64-bit counterparts.  This is
          useful for performing I/O on large files (> 2 Gigabytes) on 32-bit
          systems.  (Defining this macro permits correctly written programs to
          use large files with only a recompilation being required.)  64-bit
          systems naturally permit file sizes greater than 2 Gigabytes, and on
          those systems this macro has no effect.

答案 1 :(得分:0)

尝试将-D_FILE_OFFSET_BITS=64添加到编译行。

答案 2 :(得分:0)

您不应该使用任何这些功能的*64()版本。在64位Linux上,off_t是64位,并且一直都是。只需使用:

    int fd = open(filename, O_RDONLY);
    struct stat st;
    unsigned char *map;

    fstat(fd, &st);
    map = mmap(0, st.st_size, PROT_READ, MAP_SHARED, fd, 0);

(当然是错误检查)。我用>测试了上面的内容。 8GB文件,它工作正常。