c语言打开大于2G的文件,C语言操作大于2G的文件
最近在做视频编解码时遇到使用fseek无法定位到一个大于2G的文件尾,由于自己功底不扎实,百思不得其解,请教大神后得知在VC平台下使用_fseeki64可以解决问题,然而自己傻乎乎的在获取文件指针位置的地方依旧使用的ftell,中途调试N久也没结果。恍然醒悟后,将ftell改成和_fseeki64对应的_ftelli64即可。TIPS:1.当文件小于2G时,使用fseek和ftell可以获取文件的
最近在做视频编解码时遇到使用fseek无法定位到一个大于2G的文件尾,由于自己功底不扎实,百思不得其解,请教大神后得知在VC平台下使用_fseeki64可以解决问题,然而自己傻乎乎的在获取文件指针位置的地方依旧使用的ftell,中途调试N久也没结果。恍然醒悟后,将ftell改成和_fseeki64对应的_ftelli64即可。
TIPS:
1.当文件小于2G时,使用fseek和ftell可以获取文件的大小,必须是这两者搭配。
2.当文件大于4G时,使用_fseeki64和_ftelli64,如果不确定自己操作的文件大小建议使用_fseeki64和_ftelli64
3.这个两个函数的参数是一致的,通用。
解释一下为什么fseek无法定位大于2G的文件。看一下fseek的定义:
_Check_return_opt_ _CRTIMP int __cdecl fseek(_Inout_ FILE * _File, _In_ long _Offset, _In_ int _Origin);
第二个参数offset表示相对于标记Origin的偏移量,定义是long类型,在32位平台下,他表示的文件大小是2^31=2G。因此对于大于2G的文件他就无能为力啦。再看看_fseeki64的定义:
_Check_return_opt_ _CRTIMP int __cdecl _fseeki64(_Inout_ FILE * _File, _In_ __int64 _Offset, _In_ int _Origin);offset偏移量的定义为int64,所以这个函数可以定位的文件大小为2^63 = 8589934592G
。
TIPS:
1.fseek,_fseeki64是带缓冲的,如果不进行文件读写时,文件指针是空的,不会移动的,调试的时候不能通过判断文件指针的值来判断定位是否成功,而是判断函数的返回值。
2.fread和fwrite不受文件大小的限制
3.如果遇到使用_fseeki64不成功的话,尝试在加上以下宏定义:
#define __USE_FILE_OFFSET64
#define _LARGEFILE64_SOURCE
#define _FILE_OFFSET_BITS 64
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)