MFC-標準I / O

MFCライブラリは、独自のバージョンのファイル処理を提供します。これは、CStdioFileという名前のクラスを介して行われます。CStdioFileクラスはCFileから派生しています。通常のマルチバイトテキストファイルだけでなく、Unicodeテキストファイルの読み取りと書き込みも処理できます。

CStdioFileオブジェクトを初期化できるコンストラクターのリストは次のとおりです-

CStdioFile();
CStdioFile(CAtlTransactionManager* pTM);
CStdioFile(FILE* pOpenStream);
CStdioFile(LPCTSTR lpszFileName, UINT nOpenFlags);
CStdioFile(LPCTSTR lpszFileName, UINT nOpenFlags, CAtlTransactionManager* pTM);

これがCStdioFileのメソッドのリストです-

シニア番号 名前と説明
1

Open

オーバーロード。Openは、デフォルトのCStdioFileコンストラクターで使用するように設計されています(CFile :: Openをオーバーライドします)。

2

ReadString

1行のテキストを読み取ります。

3

Seek

現在のファイルポインタを配置します。

4

WriteString

1行のテキストを書き込みます。

新しいMFCダイアログベースのアプリケーションを作成して、簡単な例をもう一度見てみましょう。

Step 1 −次のスナップショットに示すように、1つの編集コントロールと2つのボタンをドラッグします。

Step 2 −値変数を追加 m_strEditCtrl 編集制御用。

Step 3 − [開く]ボタンと[保存]ボタンのクリックイベントハンドラーを追加します。

Step 4 −これがイベントハンドラーの実装です。

void CMFCStandardIODlg::OnBnClickedButtonOpen() {
   
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);

   CStdioFile file;
   file.Open(L"D:\\MFCDirectoryDEMO\\test.txt", CFile::modeRead | CFile::typeText);
   
   file.ReadString(m_strEditCtrl);
   file.Close();
   UpdateData(FALSE);
}

void CMFCStandardIODlg::OnBnClickedButtonSave() {
   
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   CStdioFile file;
   if (m_strEditCtrl.GetLength() == 0) {

      AfxMessageBox(L"You must specify the text.");
      return;
   }
   file.Open(L"D:\\MFCDirectoryDEMO\\test.txt", CFile::modeCreate |
      CFile::modeWrite | CFile::typeText);
   file.WriteString(m_strEditCtrl);
   file.Close();
}

Step 5 −上記のコードをコンパイルして実行すると、次の出力が表示されます。

Step 6−何かを書いて、[保存]をクリックします。データは* .txtファイルに保存されます。

Step 7 −ファイルの場所を見ると、test.txtファイルが含まれていることがわかります。

Step 8−ここで、アプリケーションを閉じます。同じアプリケーションを実行します。[開く]をクリックすると、同じテキストが再度読み込まれます。

Step 9 −ファイルを開き、ファイルを読み取り、編集コントロールを更新することから始まります。