![]() |
Development Lifecycle »
Debug Tips »
General
Beginner
Creating a console for your MFC app's debug outputBy matthias s.How to send debugging output to a console in a MFC application |
VC6, MFC, Dev, QA
|
|
Advanced Search |
|
|
|
||||||||||||||||

A last word of warning beforehand: Closing the console window will exit your application! Let's go:
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.
_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 }
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!
| You must Sign In to use this message board. | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
General
News
Question
Answer
Joke
Rant
Admin
|
PermaLink |
Privacy |
Terms of Use
Last Updated: 17 Jun 2000 Editor: Tim Deveaux |
Copyright 2000 by matthias s. Everything else Copyright © CodeProject, 1999-2009 Web16 | Advertise on the Code Project |