读取文件async-iso文件c++

Readfile async - iso files c++

本文关键字:文件 c++ async-iso 读取      更新时间:2023-10-16

在我的c++应用程序中,我正试图通过createfile异步读取iso文件-带有重叠标志,之后是readfile。然而,当我在一个简单的文件(例如txt文件)上尝试这个代码时,它是有效的。但当我在iso文件上运行此代码时,它失败了。我在MSDN中看到,压缩文件只能通过readfile同步调用读取。iso文件属于这一类吗?如果是-你有其他建议如何异步读取iso文件吗?

这是我的代码:

int _tmain(int argc, _TCHAR* argv[])
{

HANDLE hFile;
    DWORD NumberOfBytesRead = 0, dw;
    BYTE *buf = (BYTE*)malloc(BUF_SIZE*sizeof(BYTE));
    OVERLAPPED overlapped;
    overlapped.Offset = overlapped.OffsetHigh = 0;  
    memset(buf, 0, 1024);
overlapped.hEvent = CreateEvent(NULL, true, false, NULL); 
if(NULL == overlapped.hEvent)
    printf("error");
hFile = CreateFile("xxx.iso",
                  GENERIC_READ,
                  FILE_SHARE_READ,
                  NULL,
                  OPEN_EXISTING,
    FILE_FLAG_OVERLAPPED | FILE_ATTRIBUTE_NORMAL | FILE_FLAG_NO_BUFFERING , 
                  NULL);

if (hFile == INVALID_HANDLE_VALUE)
        printf("invalid hfilen");
   int i;   
   i= ReadFile(hFile,
                 buf,
                 BUF_SIZE,
                 &NumberOfBytesRead,
        &overlapped);
   if( GetLastError() == ERROR_IO_PENDING)
   {

       dw = WaitForSingleObject(overlapped.hEvent, INFINITE);
    if(dw ==  WAIT_OBJECT_0)
        if (GetOverlappedResult(hFile,&overlapped,&NumberOfBytesRead, TRUE) != 0)   
        {
            if (NumberOfBytesRead != 0) 
            {
                printf("!!!n");
            }
        }
   }

感谢

您还没有公布BUF_SIZE常量的值,但请确保它是卷扇区大小的整数倍。当使用未缓冲的文件流时,这是一个常见的陷阱。CreateFile()文档中的FILE_FLAG_NO_BUFFERING文档显示:

使用FILE_FLAG_NO_BUFFERING标志成功使用CreateFile打开的文件有严格的要求,有关详细信息,请参阅文件缓冲。

文件缓冲说明页面:

如前所述,应用程序在工作时必须满足某些要求使用FILE_FLAG_NO_BUFFERING打开的文件。以下具体情况适用:

  • 文件访问大小,包括OVERLAPPED结构中的可选文件偏移量,如果指定的字节数必须是卷扇区的整数倍大小例如,如果扇区大小为512字节,则应用程序可以请求读取并512、1024、1536或2048字节的写入,但不是335、981或7171字节的写入。

  • 用于读取和写入操作的文件访问缓冲区地址应为物理扇区对齐,这意味着在内存中的地址上对齐,这些地址是卷的物理扇区大小。根据磁盘的不同,此要求可能不是强制执行。

应用程序开发人员应注意新类型的存储设备以4096字节的物理媒体扇区大小引入市场

在我的系统上,这个值是4K,一次读取任何小于4K的内容都会产生错误。在微软的许多代码示例中,1K是默认的缓冲区大小,因此调整示例通常会导致未缓冲I/O的错误。

编辑:同时确保将OVERLAPPED结构的所有成员清零。您没有将InternalInternalHigh成员设置为0。始终以以下方式清除OVERLAPPED结构:

OVERLAPPED overlapped;
ZeroMemory(&overlapped, sizeof(OVERLAPPED));

然后,您可以设置文件偏移量和事件句柄。

编辑:还要考虑以下关于lpNumberOfBytesRead参数到ReadFile():的注意事项

如果这是一个异步操作,请对此参数使用NULL,以避免潜在的错误结果。[…]有关详细信息,请参阅备注部分。

我建议仔细注意重叠的OffsetOffsetHigh字段,尤其是在读取大小超过32位无符号整数边界的文件时。我相信你面临的问题就潜伏在那里。

如果像Dodo所说的那样调用GetLastError(),即使没有错误,也会更好。ReadFile返回的内容将非常有帮助。就ISO文件而言,我认为它们是压缩文件类型。不过,您可以查找使用LzRead函数。下面我们来看看:"

http://msdn.microsoft.com/en-us/library/windows/desktop/aa365226%28v=vs.85%29.aspx
"。您也可以使用LzOpenFile打开该文件。
http://msdn.microsoft.com/en-us/library/windows/desktop/aa365225%28v=vs.85%29.aspx
希望能有所帮助。在这个话题上找不到太多。