MFC-표준 I / O

MFC 라이브러리는 자체 버전의 파일 처리를 제공합니다. 이는 CStdioFile이라는 클래스를 통해 수행됩니다. CStdioFile 클래스는 CFile에서 파생됩니다. 유니 코드 텍스트 파일과 일반 멀티 바이트 텍스트 파일의 읽기 및 쓰기를 처리 할 수 ​​있습니다.

다음은 CStdioFile 객체를 초기화 할 수있는 생성자 목록입니다.

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

다음은 CStdioFile의 메소드 목록입니다.

Sr. 아니. 이름 및 설명
1

Open

과부하. Open은 기본 CStdioFile 생성자 (CFile :: Open 재정의)와 함께 사용하도록 설계되었습니다.

2

ReadString

한 줄의 텍스트를 읽습니다.

Seek

현재 파일 포인터를 배치합니다.

4

WriteString

한 줄의 텍스트를 씁니다.

새로운 MFC 대화 상자 기반 응용 프로그램을 만들어 간단한 예제를 다시 살펴 보겠습니다.

Step 1 − 다음 스냅 샷과 같이 하나의 편집 컨트롤과 두 개의 버튼을 드래그합니다.

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 − 파일 열기, 파일 읽기, 편집 컨트롤 업데이트로 시작됩니다.