SetFilePointer设置文件指针使用示例(可用于读取大文件!!!)

48 篇文章 0 订阅
SetFilePointer设置文件指针使用示例

#include "stdafx.h"




int _tmain(int argc, _TCHAR* argv[])
{
    _tsetlocale(LC_CTYPE, _T(""));
    HANDLE hFile;
    CHAR buffer[256] = {};
    DWORD nByte;




    hFile = CreateFile(_T("a.txt"), GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); 
    ReadFile(hFile, buffer, 256, &nByte, NULL);
    buffer[nByte] = '';
    _ftprintf(stdout, _T("a.txt 中的原始字符串: %S"), buffer);


    SetFilePointer(hFile, 6, NULL, FILE_BEGIN);
    
    ReadFile(hFile, buffer, 7, &nByte, NULL);
    buffer[nByte] = '';
    _ftprintf(stdout, _T("
从开头偏移 6 个字符调整后读:%S"), buffer);
     
    SetFilePointer(hFile, 8, NULL, FILE_CURRENT);
    ReadFile(hFile, buffer, 7, &nByte, NULL);
    buffer[nByte] = '';
    _ftprintf(stdout, _T("


从当前位置偏移 8 个字符调整后读:%S"), buffer);


    _ftprintf(stdout, _T("


文件总大小为:%d
"), SetFilePointer(hFile, 0, NULL, FILE_END));    //从文件末尾移动 0 个字节以得到文件的长度




    CloseHandle(hFile);


    return 0;
}
[喝小酒的网摘]http://blog.hehehehehe.cn/a/17049.htm
运行输出:
D:WindowsAPPsetfpDebug>setfp.exe
a.txt 中的原始字符串: hello windows system programming
从开头偏移 6 个字符调整后读:windows
从当前位置偏移 8 个字符调整后读:program
文件总大小为:35


SetFilePointer() -- 设置文件指针


SetFilePointer() 函数用来移动文件指针,它和 Unix 中的 lseek() 函数以及 C 库中的 fseek() 函数是类似的。该函数原型声明如下:
复制代码
DWORD WINAPI SetFilePointer(
  __in         HANDLE hFile,
  __in         LONG lDistanceToMove,
  __inout_opt  PLONG lpDistanceToMoveHigh,
  __in         DWORD dwMoveMethod
);


第 1 个参数为要操作的文件句柄;


第 2 个参数是一个 32 位有符号 LONG 型( 32 位系统平台),它代表要移动的距离; 


第 3 个参数是指向移动距离值的高序部分,如果这个值设置为 NULL,那么函数只能对长度限制在 (2^31 - 1) 之内的文件进行操作 ,因为这个是有符号的 LONG 型。如果该值非 NULL,那么 lpDistanceToMoveHigh 和 lDistanceToMove 合起来就能进行 64 位有符号的移动,而此时这个参数还用于接收文件指针的高序位返回值,而低序位部分由函数的返回值返回。


如果函数返回值不为  INVALID_SET_FILE_POINTER (-1) ,那么说明函数是执行成功的,这时就无需再调用 GetLastError() 函数进行检查。


然 而需要注意的是,INVALID_SET_FILE_POINTER 对于低序位部分是个有效值。也就是说,当设定了lpDistanceToMoveHigh 时,低序位可以寻址到 0xFFFFFFFF 这里,如果函数执行成功那么返回值是 -1,这时因为函数的返回既代表了文件位置又代表了错误代码,所以还需要用 GetLastError() 来确认一下是不是确实发生了错误,如果没有错误那么会返回 NO_ERROR ,若发生了错误,那么返回值就不是位置,而是一个  INVALID_SET_FILE_POINTER 。因此一般情况下,这时会将文件的长度单位限制在 (2^32 - 2) ,这样就避开了要调用 GetLastError() 的必要。


在操作巨型文件时才需要设置第 3 个参数,但是使用 SetFilePointer() 函数来操作巨型文件会显得有些笨拙,对于这种情况可以选择它的增强型 SetFilePointerEx() 则更加容易。


第 4 个参数是移动模式,一共有 3 种:
FILE_BEGIN : 从文件开始的位置进行定位,此时 lDistanceToMove 被解释为无符号型。
FILE_CURRENT : 从文件的当前位置向前或向后移动指针, lDistanceToMove 被解释为有符号型,正数代表向前,负数表示向后。
FILE_END : 从文件的末位向前或向后定位指针。


另外,通过制定从文件尾进行长度为 0 的移动,可以获得文件长度,这个长度值通过函数的返回值可知。[喝小酒的网摘]http://blog.hehehehehe.cn/a/17049.htm
转载自 [blog.hehehehehe.cn]喝小酒的网摘 及本文链接地址:http://blog.hehehehehe.cn/a/17049.htm
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用SetFilePointer函数设置文件指针偏移量后,可以使用ReadFile函数读取文件中指定位置的数据。ReadFile的函数原型如下: ```C++ BOOL ReadFile( HANDLE hFile, // 文件句柄 LPVOID lpBuffer, // 读取数据缓冲区 DWORD nNumberOfBytesToRead, // 要读取的字节数 LPDWORD lpNumberOfBytesRead, // 实际读取的字节数 LPOVERLAPPED lpOverlapped // 指向OVERLAPPED结构的指针用于异步操作 ); ``` 其中,hFile参数是文件句柄,lpBuffer参数是读取数据的缓冲区指针,nNumberOfBytesToRead参数是要读取的字节数,lpNumberOfBytesRead参数是实际读取的字节数,lpOverlapped参数用于指定异步操作时的状态和回调函数等信息,这里不做详细介绍。 例如,如果要读取偏移量为100的位置开始的10个字节,可以这样写: ```C++ HANDLE hFile = CreateFile( L"file.txt", GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL ); DWORD dwPos = SetFilePointer(hFile, 100, NULL, FILE_BEGIN); char buf[10]; DWORD dwRead; BOOL bRet = ReadFile(hFile, buf, 10, &dwRead, NULL); if (bRet && dwRead > 0) { // 读取成功 // 在buf中保存了读取的数据 } ``` 这里使用了CreateFile函数创建一个名为“file.txt”的文件,并且打开方式为读写模式。然后使用SetFilePointer函数将文件指针偏移100个字节。接着定义一个长度为10的char类型数组buf作为读取数据的缓冲区,使用ReadFile函数将文件中偏移量为100的位置开始的10个字节读取到buf中,实际读取的字节数保存在dwRead中。如果读取成功,就可以在buf中获取读取到的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值