CFile::Open
多載。 開啟 是專為與 CFile 預設建構函式的使用。
virtual BOOL Open(
LPCTSTR lpszFileName,
UINT nOpenFlags,
CFileException* pError = NULL
);
virtual BOOL Open(
LPCTSTR lpszFileName,
UINT nOpenFlags,
CAtlTransactionManager* pTM,
CFileException* pError = NULL
);
參數
lpszFileName
是路徑設定為所要的檔案的字串。 路徑可以是相對或絕對,網路名稱 (UNC)。nOpenFlags
定義文件和存取共用狀態的 UINT 。 在開啟檔案時,它會指定要執行的動作。 您可以合併選項使用位元 OR ( |) 運算子。 需要一個存取權限和一個共用選項, modeCreate 和 modeNoInherit 模式是選擇性的。 根據使用者的選擇清單 C 檔案 參閱建構函式。pError
要接收作業失敗狀態的現有檔案例外狀況物件的指標。pTM
為 CAtlTransactionManager 物件的指標。
傳回值
如果不是零,開啟成功,則為 0。 才會傳回 0, pError 參數是有意義的。
備註
兩個函式會開啟的失敗是一般的檔案,必須有一個條件的「安全性」方法。
當 CFile 建構函式就會擲回發生錯誤狀況時的例外狀況, 開啟 會傳回錯誤條件的 否 。 不過開啟 仍然可以初始化 CFileException 物件描述錯誤。 如果您不提供 pError 參數,或者,如果您傳遞的 pErrorNULL , 開啟 會傳回 否 並不會擲回 CFileException。 如果您將指標傳遞給現有的 CFileException和 開啟 遇到錯誤,函式是描述該錯誤的資訊會填滿它。 在兩種情況下都不會 開啟 擲回例外狀況。
下表說明 開啟的可能結果。
pError |
遇到的錯誤? |
傳回值 |
CFileException 內容 |
---|---|---|---|
NULL |
否 |
TRUE |
N/A |
為 CFileException的 ptr |
否 |
TRUE |
不會變更。 |
NULL |
是 |
FALSE |
N/A |
為 CFileException的 ptr |
是 |
FALSE |
初始化描述錯誤 |
範例
CFile f;
CFileException e;
TCHAR* pszFileName = _T("Open_File.dat");
if(!f.Open(pszFileName, CFile::modeCreate | CFile::modeWrite, &e))
{
TRACE(_T("File could not be opened %d\n"), e.m_cause);
}
//A second example for CFile::Open.
//This function uses CFile to copy binary files.
bool BinaryFileCopy(LPCTSTR pszSource, LPCTSTR pszDest)
{
// constructing these file objects doesn't open them
CFile sourceFile;
CFile destFile;
// we'll use a CFileException object to get error information
CFileException ex;
// open the source file for reading
if (!sourceFile.Open(pszSource,
CFile::modeRead | CFile::shareDenyWrite, &ex))
{
// complain if an error happened
// no need to delete the ex object
TCHAR szError[1024];
ex.GetErrorMessage(szError, 1024);
_tprintf_s(_T("Couldn't open source file: %1024s"), szError);
return false;
}
else
{
if (!destFile.Open(pszDest, CFile::modeWrite |
CFile::shareExclusive | CFile::modeCreate, &ex))
{
TCHAR szError[1024];
ex.GetErrorMessage(szError, 1024);
_tprintf_s(_T("Couldn't open source file: %1024s"), szError);
sourceFile.Close();
return false;
}
BYTE buffer[4096];
DWORD dwRead;
// Read in 4096-byte blocks,
// remember how many bytes were actually read,
// and try to write that many out. This loop ends
// when there are no more bytes to read.
do
{
dwRead = sourceFile.Read(buffer, 4096);
destFile.Write(buffer, dwRead);
}
while (dwRead > 0);
// Close both files
destFile.Close();
sourceFile.Close();
}
return true;
}
需求
Header: afx.h