FILE是常量或结构或两者

时间:2016-11-03 10:18:15

标签: c file

FILE

  1. 是不变的? (想想,它是大写的)(但我读过,FILE struct stdio.h中的%S = %SOURCE 类型
  2. (或)是一个结构?如果是结构,为什么它是大写?

2 个答案:

答案 0 :(得分:3)

FILE opaque 类型。它通常是一个包含文件描述符,错误标志等的结构。但C标准对其内部结构没有任何说明。

为什么你需要知道?您将使用标准接口,而不必担心它是如何实现的。

C11标准中FILE的定义,§7.21.1(N1548草案):

  

是能够记录所有信息的对象类型   需要控制流,包括其文件位置指示器,a   指向其关联缓冲区(如果有)的指针,一个错误指示符   记录是否发生了读/写错误,以及文件结束   记录是否已到达文件末尾的指示符;

并未提供任何进一步的信息。因此,实现可以以他们认为合适的任何方式自由实现。

作为一个例子,这就是glibc实现的内容。但是 - 正如我之前所说 - 它是一个实现细节,因此你不能依赖它:

struct _IO_FILE {
  int _flags;       /* High-order word is _IO_MAGIC; rest is flags. */
#define _IO_file_flags _flags

  /* The following pointers correspond to the C++ streambuf protocol. */
  /* Note:  Tk uses the _IO_read_ptr and _IO_read_end fields directly. */
  char* _IO_read_ptr;   /* Current read pointer */
  char* _IO_read_end;   /* End of get area. */
  char* _IO_read_base;  /* Start of putback+get area. */
  char* _IO_write_base; /* Start of put area. */
  char* _IO_write_ptr;  /* Current put pointer. */
  char* _IO_write_end;  /* End of put area. */
  char* _IO_buf_base;   /* Start of reserve area. */
  char* _IO_buf_end;    /* End of reserve area. */
  /* The following fields are used to support backing up and undo. */
  char *_IO_save_base; /* Pointer to start of non-current get area. */
  char *_IO_backup_base;  /* Pointer to first valid character of backup area */
  char *_IO_save_end; /* Pointer to end of non-current get area. */

  struct _IO_marker *_markers;

  struct _IO_FILE *_chain;

  int _fileno;
#if 0
  int _blksize;
#else
  int _flags2;
#endif
  _IO_off_t _old_offset; /* This used to be _offset but it's too small.  */

#define __HAVE_COLUMN /* temporary */
  /* 1+column number of pbase(); 0 is unknown. */
  unsigned short _cur_column;
  signed char _vtable_offset;
  char _shortbuf[1];

  /*  char* _save_gptr;  char* _save_egptr; */

  _IO_lock_t *_lock;
#ifdef _IO_USE_OLD_IO_FILE
};

struct _IO_FILE_complete
{
  struct _IO_FILE _file;
#endif
#if defined _G_IO_IO_FILE_VERSION && _G_IO_IO_FILE_VERSION == 0x20001
  _IO_off64_t _offset;
# if defined _LIBC || defined _GLIBCPP_USE_WCHAR_T
  /* Wide character stream stuff.  */
  struct _IO_codecvt *_codecvt;
  struct _IO_wide_data *_wide_data;
  struct _IO_FILE *_freeres_list;
  void *_freeres_buf;
# else
  void *__pad1;
  void *__pad2;
  void *__pad3;
  void *__pad4;
# endif
  size_t __pad5;
  int _mode;
  /* Make sure we don't get into trouble again.  */
  char _unused2[15 * sizeof (int) - 4 * sizeof (void *) - sizeof (size_t)];
#endif
};

答案 1 :(得分:2)

C标准故意模糊FILE的确切构成。

它或指向它的指针只是可以传递给C标准库的各种输入/输出函数的东西。

有时候将FILE*视为“指向文件的指针”可能会有所帮助,但不一定如此。

(我认为大写惯例早在20世纪70年代出现,当时它是许多早期标准化C的早期实现中的一个宏。)