Solved

OutputDebugString()

Posted on 2001-06-20
18
743 Views
Last Modified: 2007-11-27
In a VC6 WinAPI program, is it necessary to enclose OutputDebugString() calls in #ifdef _DEBUG blocks, or is the function removed in release builds (like with the TRACE() macro)?

If the function call (and overhead) are not removed in release mode, then does the WinAPI or CRT provide a suitable substitute?
0
Comment
Question by:TookH
  • 5
  • 5
  • 3
  • +2
18 Comments
 
LVL 5

Expert Comment

by:djbusychild
ID: 6213204
the function really doesn't have to do with the "debug" mode. it simply sends strings to the debugger ( i.e. dbwin32 ) it will look for a debugger that it can hook to, if none is available it'll just not to anything. if you don't want it in your release code you should #ifdef it
0
 
LVL 6

Expert Comment

by:MichaelS
ID: 6213493
It's a fucntion (like was mentioned earlie). Usually I define another function like:

Trace(LPSTR szString)
{  
#ifndef _DEBUG
OutputDebugString(szString);
#endif
}

and I use it evrywhere in my code where I want to have some traces.
0
 
LVL 86

Expert Comment

by:jkr
ID: 6214195
You don't HAVE to guard that, but anybodz witha tracer tool will be able to see the output.

BUT:

#ifdef _DEBUG
#define ODS( x) OutputDebugString ( x)
#else
#define ODS( x)

would do it more 'globally'...
0
 
LVL 1

Author Comment

by:TookH
ID: 6216167
jkr, I like your suggestion. I'm thinking of doing something like this:

void OutputDebug( char *s, ... )
{
    va_list argList;
    char msg[256];

    va_start( argList, s );
    vsprintf( msg, s, argList);
    va_end( argList );

    OutputDebugString( msg );
}

Then I could use a macro like yours to invoke it only in debug builds. I'm not sure if it's possible to pass variable argument lists to a macro, though. Any suggestions?
0
 
LVL 86

Accepted Solution

by:
jkr earned 50 total points
ID: 6216211
>>I'm not sure if it's possible
>>to pass variable argument lists to a macro, though. Any
>>suggestions?

Well, you cannot use variable arguments in a macro - but you can remedy the overhead in the function calls by using

void OutputDebug( char *s, ... )
{
#ifdef _DEBUG
   va_list argList;
   char msg[256];

   va_start( argList, s );
   vsprintf( msg, s, argList);
   va_end( argList );

   OutputDebugString( msg );
#endif
}

Alternatively, you could go the way e.g. MFC does:

#ifdef _DEBUG
#define OutputDebug0( psz)                  OutputDebug     ( psz)
#define OutputDebug1( psz, p1)              OutputDebug     ( psz, p1)
#define OutputDebug2( psz, p1, p2)          OutputDebug     ( psz, p1, p2)
#define OutputDebug3( psz, p1, p2, p3)      OutputDebug     ( psz, p1, p2, p3)
#define OutputDebug4( psz, p1, p2, p3, p4)  OutputDebug     ( psz, p1, p2, p3, p4)

#else   /*  ndef _DEBUG     */

#define OutputDebug0( psz)                  ( ( void) 0)
#define OutputDebug1( psz, p1)              ( ( void) 0)
#define OutputDebug2( psz, p1, p2)          ( ( void) 0)
#define OutputDebug3( psz, p1, p2, p3)      ( ( void) 0)
#define OutputDebug4( psz, p1, p2, p3, p4)  ( ( void) 0)

#endif  /*  ndef _DEBUG     */
0
 
LVL 5

Expert Comment

by:djbusychild
ID: 6216465
you could also remedby function call overhead by making it inline. Although there's no gurantee that it'll be inline.
0
 
LVL 1

Author Comment

by:TookH
ID: 6216626
I'm going to use #ifdef within the function body. If performance becomes critical, I'll switch to using the MFC method and/or djbusychild's suggestion.

Thanks everyone.
0
 
LVL 22

Expert Comment

by:nietod
ID: 6222843
Does anyone know if this accepted answer was posted as a comment or as an answer?
0
 
LVL 6

Expert Comment

by:MichaelS
ID: 6223653
As I remember it was a comment, why you are so interested in that?
0
How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

 
LVL 22

Expert Comment

by:nietod
ID: 6224068
We're trying to measure the number of comments vs answers.

I'm putting it down as a comment for now, if you aren't really sure, let me know (or if someone else is sure.)
0
 
LVL 6

Expert Comment

by:MichaelS
ID: 6224290
I am not really sure, it's just a guess.
0
 
LVL 22

Expert Comment

by:nietod
ID: 6224305
Back into the "undecided" category....
0
 
LVL 6

Expert Comment

by:MichaelS
ID: 6224348
Somehow I think they (EE) probably sould remote answers at all, leave only comments. If it's not a secret, what is the proportion?
0
 
LVL 22

Expert Comment

by:nietod
ID: 6224508
Too early to tell, but currently 7 to 4--I think--in favor of comments.
0
 
LVL 6

Expert Comment

by:MichaelS
ID: 6224525
Well, one more question, what is the perpuse actually?
0
 
LVL 86

Expert Comment

by:jkr
ID: 6224626
It was a comment.
0
 
LVL 22

Expert Comment

by:nietod
ID: 6224854
make up your minds...  :-)
0
 
LVL 1

Author Comment

by:TookH
ID: 6243155
It was a comment.
0

Featured Post

Do You Know the 4 Main Threat Actor Types?

Do you know the main threat actor types? Most attackers fall into one of four categories, each with their own favored tactics, techniques, and procedures.

Join & Write a Comment

Introduction This article is the first in a series of articles about the C/C++ Visual Studio Express debugger.  It provides a quick start guide in using the debugger. Part 2 focuses on additional topics in breakpoints.  Lastly, Part 3 focuses on th…
This article will show you some of the more useful Standard Template Library (STL) algorithms through the use of working examples.  You will learn about how these algorithms fit into the STL architecture, how they work with STL containers, and why t…
The viewer will learn how to pass data into a function in C++. This is one step further in using functions. Instead of only printing text onto the console, the function will be able to perform calculations with argumentents given by the user.
The viewer will be introduced to the member functions push_back and pop_back of the vector class. The video will teach the difference between the two as well as how to use each one along with its functionality.

747 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

12 Experts available now in Live!

Get 1:1 Help Now