조회 수 43370 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print

출처 : http://www.codeproject.com/KB/debug/mfcconsole.aspx

Sample Image - MFCConsole.gif

It's simply a matter of three function calls to print a message to a console in your MFC application. There are several reasons why you might want to send your debugging output to a console. Mine were, that 1st, I didn't have an IDE on the PC where I tested the debug-builds of my app and 2nd, the Mainframe was not always visible, which made matters worse.

A last word of warning beforehand: Closing the console window will exit your application! Let's go:

Creating the console

To create a console window you need to call AllocConsole(). This function does not take any parameters and returns a BOOL, indicating whether the console has been created or not. You should create the console sometime in the beginning of your code. In the sample I've put the code into the CWinApp::OnInitInstance() override. Like this:

BOOL CSmplConsoleApp::InitInstance()
{
	// details omitted

	// allocate a console
#ifdef _DEBUG
	if (!AllocConsole())
		AfxMessageBox("Failed to create the console!", MB_ICONEXCLAMATION);
#endif
	return TRUE;
	
	//	and then create the frame
	pFrame->LoadFrame(IDR_MAINFRAME,
		WS_OVERLAPPEDWINDOW | FWS_ADDTOTITLE, NULL,
		NULL);

	// The one and only window has been initialized, so show and update it.
	pFrame->ShowWindow(SW_SHOW);
	pFrame->UpdateWindow();
}

It is important that you create your console before you create the main window. If you don't, the console will still be created, but your debugging messages send with _cprintf() will not arrive in your console. I couldn't figure out why it is like this, only that it is like this. If somebody has an explanation, please let me know.

Writing to the console

Send your output to the console via _cprintf(), which is prototyped like this:

int _cprintf( const char *format [, argument] ... );

The format has the same form and function as the format parameter for the printf() function. Please look up the details in your documentation. And don't forget to #include <conio.h> wherever you use _cprintf().

The CChildView::OnPaint() override in the demo application looks like this:

void CChildView::OnPaint() 
{
	CPaintDC dc(this); // device context for painting
	
	// TODO: Add your message handler code here
#ifdef _DEBUG
	static int nCallCounter = 0;
	nCallCounter++;
	_cprintf("Window painted now %i time(s)\n", nCallCounter);
#endif
	// Do not call CWnd::OnPaint() for painting messages
}

Getting rid of the console

Somewhere near the end of your program you should call FreeConsole() to free the console <g>. Again, this function does not take any parameters and returns a BOOL indicating success or failure. Here is what the CWinApp::ExitInstance() override in the demo project looks like:

int CSmplConsoleApp::ExitInstance() 
{
	//	deallocate console
#ifdef _DEBUG
	if (!FreeConsole())
		AfxMessageBox("Could not free the console!");
#endif
	return CWinApp::ExitInstance();
}

Hope that helps!

.


Dreamy의 코드 스크랩

내가 모으고 내가 보는

List of Articles
번호 분류 제목 날짜 조회 수 추천 수
56 LINUX 우분투 root 계정 사용하기 2014.06.18 8493 0
55 LINUX 우분투(Ubuntu) 설치된 패키지 목록 확인하기 2020.02.11 21316 0
54 LINUX 우분투(Ubuntu) 설치된 패키지 목록 확인하기 2016.03.17 7352 0
53 LINUX 우분투(Ubuntu)에서 APM 웹서버 구축하기 2016.03.17 7997 0
52 Android 원격 linux 서버에서 local device로 adb 접속하기 secret 2015.11.05 1 0
51 C# 윈도우 App 설정값 유지하기 (Properties.Settings.Default. , Settings.settings 이용) 2015.08.03 16672 0
50 PHP 윈도우용 센드메일 구축 2016.03.30 8962 0
49 Python 유용한 Python 함수 및 기능들 2014.04.30 12052 0
48 Android 이클립스(Eclipse)에서 유용한 단축키 일람 1 2013.05.21 39608 0
47 C# 인터넷 연결상태 확인 2013.02.01 18015 0
46 C 입출력 파일을 표준입력으로 받아 열기 2005.08.05 29955 0
45 Android 자바 call stack을 임의로 보는 방법 2012.09.05 18190 0
44 JAVA 자바 리스트(List,ArrayList) 이용하는 방법 2016.02.22 29335 0
43 JAVA 자바 프로그래머가 알아야할 10가지 이클립스 단축키 1 2015.10.27 8216 0
42 C# 자신의 IP주소 확인하기 2013.02.01 23355 0
목록
Board Pagination ‹ Prev 1 ... 26 27 28 29 30 31 32 33 34 Next ›
/ 34

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소

Designed by sketchbooks.co.kr / sketchbook5 board skin

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5