tags:

views:

400

answers:

3

What's the difference between Console.WriteLine() vs Debug.WriteLine()?

+16  A: 

Console.WriteLine write to the standard output stream, either in debug or release. Debug.WriteLine writes to the trace listeners in the Listeners collection, but only when running in debug, when the app is compiled in release configuration the Debug elements will not be compiled into the code.

As Debug.WriteLine writes to all the trace listeners in the the Listeners collection, it is possible that this could be output in more than one place (VS output window, Console, Log file, 3rd party app which registers a listener (I believe DebugView does this) etc)

Sam Holder
Strictly DebugView monitors messages logged through the native Windows API call `OutputDebugString` (and `DebugPrint`). The `DefaultTraceListener` writes to `OutputDebugString`, which is why DebugView sees the output. http://msdn.microsoft.com/en-us/library/system.diagnostics.defaulttracelistener.aspx
MarkJ
Thanks for the clarification MarkJ, I wasn't sure exactly how it worked.
Sam Holder
+3  A: 

Console.WriteLine() is meant for console mode programs. A nice feature of Visual Studio hosting process makes its output appear in the Visual Studio Output window while debugging for processes that don't have a console. That's very useful while debugging but beware that you should remove this code (or wrap it with a #ifdef DEBUG) when you're ready to create the Release build. It will otherwise add unnecessary overhead to your program. This makes it less than ideal for debug tracing.

Debug.WriteLine() generates tracing information if you build with the DEBUG conditional #defined. Which is on by default in the Debug build. Where the output ends up can be configured in the app.exe.config file. If this config is not overridden, .NET automatically provides an instance of the DefaultTraceListener class. It sends the Debug.WriteLine() text with the Windows OutputDebugString() API function to the debugger. The Visual Studio debugger makes that appear in the Output window, just like Console.WriteLine().

A clear advantage of Debug.WriteLine() is that it generates no overhead in the Release build, the calls are effectively removed. It however does not support composite formatting, you'll need String.Format() for that. For debug tracing, the Debug class should be your choice.

Hans Passant
+3  A: 

If your purpose of using console.writeline is solely for debugging, you better use debug.writeline.

If you want to show a message to your user, you would use console.writeline.

Debug.writeline is only for the purpose of debugging your application. In the release mode your debug statements will be ignored.

Another usage of a console app is to test private assemblies. Rather than the traditional approach of creating some sort of GUI test harness to test the compiled version of the DLL, you can simply re-build the DLL as a console app and input/output from/to the console. I have found this technique to be faster than spending time creating a GUI test harness.