用CFile类读取大文件

随着Windows 2000和XP的普及,现在的大文件越来越多,而VC6中MFC的CFile类只支持不大于4GB的文件, 原因在于CFile类中 使用了32位整型来处理文件,32位数的范围是2的32次方(4GB),超过这个范围的文件CFile就管不了,微软.Net中VC7的CFile类支持 大于4GB的文件,而.Net还不普及,开发桌面应用VC6还是首选,所以我们可以参照VC7写一个CFile的继承类CFile64,使它支持大于 4GB的文件: 
  1. class CFile64 : public CFile
  2. {
  3. public:
  4. // Attributes
  5. ULONGLONG GetPosition();
  6. // Overridables
  7. virtual ULONGLONG Seek(LONGLONG lOff, UINT nFrom);
  8. virtual void SetLength(ULONGLONG dwNewLen);
  9. ULONGLONG GetLength() ;
  10. virtual void LockRange(ULONGLONG dwPos, ULONGLONG dwCount);
  11. virtual void UnlockRange(ULONGLONG dwPos, ULONGLONG dwCount);
  12. };
  13. #include "stdafx.h"
  14. #include "file64.h"
  15. // CFile64 implementation
  16. ULONGLONG CFile64::Seek(LONGLONG lOff, UINT nFrom)
  17. {
  18. ASSERT_VALID(this);
  19. ASSERT((HANDLE)m_hFile != INVALID_HANDLE_VALUE);
  20. ASSERT(nFrom == begin || nFrom == end || nFrom == current);
  21. ASSERT(begin == FILE_BEGIN && end == FILE_END && current == FILE_CURRENT);
  22.    LARGE_INTEGER liOff;
  23.    liOff.QuadPart = lOff;
  24. liOff.LowPart = ::SetFilePointer((HANDLE)m_hFile, liOff.LowPart, &liOff.HighPart,
  25.    (DWORD)nFrom);
  26. if (liOff.LowPart  == (DWORD)-1)
  27.    if (::GetLastError() != NO_ERROR)
  28.      CFileException::ThrowOsError((LONG)::GetLastError(), m_strFileName);
  29. return liOff.QuadPart;
  30. }
  31. ULONGLONG CFile64::GetPosition() 
  32. {
  33. ASSERT_VALID(this);
  34. ASSERT((HANDLE)m_hFile != INVALID_HANDLE_VALUE);
  35.    LARGE_INTEGER liPos;
  36.    liPos.QuadPart = 0;
  37. liPos.LowPart = ::SetFilePointer((HANDLE)m_hFile, liPos.LowPart, &liPos.HighPart , FILE_CURRENT);
  38. if (liPos.LowPart == (DWORD)-1)
  39.    if (::GetLastError() != NO_ERROR)
  40.      CFileException::ThrowOsError((LONG)::GetLastError(), m_strFileName);
  41. return liPos.QuadPart;
  42. }
  43. void CFile64::LockRange(ULONGLONG dwPos, ULONGLONG dwCount)
  44. {
  45. ASSERT_VALID(this);
  46. ASSERT((HANDLE)m_hFile != INVALID_HANDLE_VALUE);
  47.    ULARGE_INTEGER liPos;
  48.    ULARGE_INTEGER liCount;
  49.    liPos.QuadPart = dwPos;
  50.    liCount.QuadPart = dwCount;
  51. if (!::LockFile((HANDLE)m_hFile, liPos.LowPart, liPos.HighPart, liCount.LowPart, 
  52.    liCount.HighPart))
  53.    {
  54.   CFileException::ThrowOsError((LONG)::GetLastError(), m_strFileName);
  55.    }
  56. }
  57. void CFile64::UnlockRange(ULONGLONG dwPos, ULONGLONG dwCount)
  58. {
  59. ASSERT_VALID(this);
  60. ASSERT((HANDLE)m_hFile != INVALID_HANDLE_VALUE);
  61.    ULARGE_INTEGER liPos;
  62.    ULARGE_INTEGER liCount;
  63.    liPos.QuadPart = dwPos;
  64.    liCount.QuadPart = dwCount;
  65. if (!::UnlockFile((HANDLE)m_hFile, liPos.LowPart, liPos.HighPart, liCount.LowPart,
  66.    liCount.HighPart))
  67.    {
  68.   CFileException::ThrowOsError((LONG)::GetLastError(), m_strFileName);
  69.    }
  70. }
  71. void CFile64::SetLength(ULONGLONG dwNewLen)
  72. {
  73. ASSERT_VALID(this);
  74. ASSERT((HANDLE)m_hFile != INVALID_HANDLE_VALUE);
  75. Seek(dwNewLen, (UINT)begin);
  76. if (!::SetEndOfFile((HANDLE)m_hFile))
  77.   CFileException::ThrowOsError((LONG)::GetLastError(), m_strFileName);
  78. }
  79. ULONGLONG CFile64::GetLength() 
  80. {
  81. ASSERT_VALID(this);
  82.    ULARGE_INTEGER liSize;
  83.    liSize.LowPart = ::GetFileSize((HANDLE)m_hFile, &liSize.HighPart);
  84.    if (liSize.LowPart == (DWORD)-1)
  85.    if (::GetLastError() != NO_ERROR)
  86.    CFileException::ThrowOsError((LONG)::GetLastError(), m_strFileName);
  87. return liSize.QuadPart;
  88. }
  89. /



LONGLONG是64位整型,这样在理论上可支持的最大文件为18000000000GB,你也可以根据自己的需要重载CFile的其他函数。

文章出处:http://babyclub.women.sohu.com/r-program-73690-0-0-0.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值