C 参考手册
- C 语言
- C 关键词
- 预处理器
- C 标准库头文件
- 类型支持
- 程序支持工具
- 变参数函数
- 错误处理
- 动态内存管理
- 日期和时间工具
- 字符串库
- 算法
- 数值
- 文件输入/输出
- gets, gets_s
- printf, fprintf, sprintf, snprintf, printf_s, fprintf_s, sprintf_s, snprintf_s
- fopen, fopen_s
- fputc, putc
- fputs
- getchar
- putchar
- FILE
- fpos_t
- stdin, stdout, stderr
- freopen, freopen_s
- fwide
- setbuf
- setvbuf
- fclose
- fflush
- fread
- fwrite
- fgetc, getc
- fgets
- puts
- ungetc
- fgetwc
- fgetws
- fputwc, putwc
- fputws
- getwchar
- putwchar
- ungetwc
- scanf, fscanf, sscanf, scanf_s, fscanf_s, sscanf_s
- wscanf, fwscanf, swscanf, wscanf_s, fwscanf_s, swscanf_s
- vscanf, vfscanf, vsscanf, vscanf_s, vfscanf_s, vsscanf_s
- vwscanf, vfwscanf, vswscanf, vwscanf_s, vfwscanf_s, vswscanf_s
- wprintf, fwprintf, swprintf, wprintf_s, fwprintf_s, swprintf_s, snwprintf_s
- vprintf, vfprintf, vsprintf, vsnprintf, vprintf_s, vfprintf_s, vsprintf_s, vsnprintf_s
- vwprintf, vfwprintf, vswprintf, vwprintf_s, vfwprintf_s, vswprintf_s, vsnwprintf_s
- ftell
- fgetpos
- fseek
- fsetpos
- rewind
- clearerr
- feof
- ferror
- perror
- remove
- rename
- tmpfile, tmpfile_s
- tmpnam, tmpnam_s
- 本地化支持
- 原子操作库
- 线程支持库
- 实验性 C 标准库
- 有用的资源
- 符号索引
- 注释
ftell
定义于头文件 <stdio.h>
|
||
long ftell( FILE *stream ); |
||
返回流 stream
的文件位置指示器。
若流以二进制模式打开,则由此函数获得的值是从文件开始的字节数。
若流以文本模式打开,则由此函数返回的值未指定,且仅若作为 fseek() 的输入才有意义。
参数
stream | - | 要检验的文件流 |
返回值
成功时为文件位置指示器,若失败发生则为 -1L 。
失败时,设 errno 对象为实现定义的正值。
示例
ftell带错误检查
运行此代码
#include <stdio.h> #include <stdlib.h> int main(void) { /* 准备浮点值的数组。 */ #define SIZE 5 double A[SIZE] = {1.,2.,3.,4.,5.}; /* 写数组到文件。 */ FILE * fp = fopen("test.bin", "wb"); fwrite(A,sizeof(double),SIZE,fp); fclose (fp); /* 读取浮点值到数组 B。 */ double B[SIZE]; fp = fopen("test.bin","rb"); long int pos = ftell(fp); /* 位置指示器在文件起始 */ if (pos == -1L) { perror("ftell()"); fprintf(stderr,"ftell() failed in file %s at line # %d\n", __FILE__,__LINE__-4); exit(EXIT_FAILURE); } printf("%ld\n", pos); int ret_code = fread(B,sizeof(double),1,fp); /* 读取一个浮点值 */ pos = ftell(fp); /* 读取一个浮点值后的位置指示器 */ if (pos == -1L) { perror("ftell()"); fprintf(stderr,"ftell() failed in file %s at line # %d\n", __FILE__,__LINE__-4); exit(EXIT_FAILURE); } printf("%ld\n", pos); printf("%.1f\n", B[0]); /* 打印浮点值 */ return EXIT_SUCCESS; }
输出:
0 8 1.0
引用
- C11 standard (ISO/IEC 9899:2011):
- 7.21.9.4 The ftell function (p: 337-338)