TraceSource Class
Provides a set of methods and properties that enable applications to trace the execution of code and associate trace messages with their source.
Namespace: System.Diagnostics
Assembly: System (in System.dll)
The TraceSource type exposes the following members.
| Name | Description | |
|---|---|---|
![]() | TraceSource(String) | Initializes a new instance of the TraceSource class, using the specified name for the source. |
![]() | TraceSource(String, SourceLevels) | Initializes a new instance of the TraceSource class, using the specified name for the source and the default source level at which tracing is to occur. |
| Name | Description | |
|---|---|---|
![]() | Attributes | Gets the custom switch attributes defined in the application configuration file. |
![]() | Listeners | Gets the collection of trace listeners for the trace source. |
![]() | Name | Gets the name of the trace source. |
![]() | Switch | Gets or sets the source switch value. |
| Name | Description | |
|---|---|---|
![]() | Close | Closes all the trace listeners in the trace listener collection. |
![]() | Equals(Object) | Determines whether the specified object is equal to the current object. (Inherited from Object.) |
![]() | Finalize | Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.) |
![]() | Flush | Flushes all the trace listeners in the trace listener collection. |
![]() | GetHashCode | Serves as a hash function for a particular type. (Inherited from Object.) |
![]() | GetSupportedAttributes | Gets the custom attributes supported by the trace source. |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object.) |
![]() | MemberwiseClone | Creates a shallow copy of the current Object. (Inherited from Object.) |
![]() | ToString | Returns a string that represents the current object. (Inherited from Object.) |
![]() | TraceData(TraceEventType, Int32, Object) | Writes trace data to the trace listeners in the Listeners collection using the specified event type, event identifier, and trace data. |
![]() | TraceData(TraceEventType, Int32, Object[]) | Writes trace data to the trace listeners in the Listeners collection using the specified event type, event identifier, and trace data array. |
![]() | TraceEvent(TraceEventType, Int32) | Writes a trace event message to the trace listeners in the Listeners collection using the specified event type and event identifier. |
![]() | TraceEvent(TraceEventType, Int32, String) | Writes a trace event message to the trace listeners in the Listeners collection using the specified event type, event identifier, and message. |
![]() | TraceEvent(TraceEventType, Int32, String, Object[]) | Writes a trace event to the trace listeners in the Listeners collection using the specified event type, event identifier, and argument array and format. |
![]() | TraceInformation(String) | Writes an informational message to the trace listeners in the Listeners collection using the specified message. |
![]() | TraceInformation(String, Object[]) | Writes an informational message to the trace listeners in the Listeners collection using the specified object array and formatting information. |
![]() | TraceTransfer | Writes a trace transfer message to the trace listeners in the Listeners collection using the specified numeric identifier, message, and related activity identifier. |
The TraceSource class is used by applications to produce traces that can be associated with the application. TraceSource provides tracing methods that allow you to easily trace events, trace data, and issue informational traces. Trace output from TraceSource can be controlled by configuration file settings. The configuration file is located in the folder with the application executable and has the name of the application with the .config file name extension added. For example, the name of the configuration file for TraceSourceSample.exe is TraceSourceSample.exe.config. The configuration file can be used to determine where the trace information is to be sent and what levels of activity are to be traced. The following example shows the contents of a sample application configuration file.
<configuration>
<system.diagnostics>
<sources>
<source name="TraceTest" switchName="SourceSwitch"
switchType="System.Diagnostics.SourceSwitch" >
<listeners>
<add name="console" />
<remove name ="Default" />
</listeners>
</source>
</sources>
<switches>
<!-- You can set the level at which tracing is to occur -->
<add name="SourceSwitch" value="Warning" />
<!-- You can turn tracing off -->
<!--add name="SourceSwitch" value="Off" -->
</switches>
<sharedListeners>
<add name="console"
type="System.Diagnostics.ConsoleTraceListener"
initializeData="false"/>
</sharedListeners>
<trace autoflush="true" indentsize="4">
<listeners>
<add name="console" />
</listeners>
</trace>
</system.diagnostics>
</configuration>
The TraceSource class is identified by the name of a source, typically the name of the application. The trace messages coming from a particular component can be initiated by a particular trace source, allowing all messages coming from that component to be easily identified.
TraceSource defines tracing methods but does not actually provide any specific mechanism for generating and storing tracing data. The tracing data is produced by trace listeners, which are plug-ins that can be loaded by trace sources.
Note |
|---|
You should not call the tracing methods during finalization. Doing so can result in an ObjectDisposedException being thrown. |
You can customize the tracing output's target by adding or removing TraceListener instances to or from the collection stored in the TraceSource.Listeners property. By default, trace output is produced using an instance of the DefaultTraceListener class. The preceding configuration file example demonstrates removing the DefaultTraceListener and adding a ConsoleTraceListener to produce the trace output for the trace source. For more information, see <listeners> Element for <source> and <sharedListeners> Element.
Note |
|---|
Adding a trace listener to the Listeners collection can cause an exception to be thrown while tracing, if a resource used by the trace listener is not available. The conditions and the exception thrown depend on the trace listener and cannot be enumerated in this topic. It may be useful to place calls to the TraceSource methods in try/catch blocks to detect and handle any exceptions from trace listeners. |
The SourceSwitch class provides the means to dynamically control the tracing output. The preceding configuration file example shows how you can turn off tracing from a trace source and control the level at which tracing occurs. You can modify the value of the source switch without recompiling your application. For information on using the configuration file to set a switch, see Switch and How to: Configure Trace Switches.
Note |
|---|
If you modify a configuration file while an application is executing, the application must be stopped and restarted or the Refresh method must be called before the new settings take effect. |
The TraceEventType enumeration is used to define the event type of the trace message. Trace filters use the TraceEventType to determine if a trace listener should produce the trace message.
The trace listeners can optionally have an additional layer of filtering through a trace filter. If a trace listener has an associated filter, the listener calls the ShouldTrace method on that filter to determine whether or not to produce the trace information.
The trace listeners use the values of the Trace class properties Indent, IndentSize, and AutoFlush to format trace output. You can use configuration file attributes to set the Indent, IndentSize, and AutoFlush properties. The following example sets the AutoFlush property to false and the IndentSize property to 3.
<configuration>
<system.diagnostics>
<trace autoflush="false" indentsize="3" />
</system.diagnostics>
</configuration>
Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (Server Core Role not supported), Windows Server 2008 R2 (Server Core Role supported with SP1 or later; Itanium not supported)
The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.
.gif?cs-save-lang=1&cs-lang=fsharp)
.gif?cs-save-lang=1&cs-lang=fsharp)
.gif?cs-save-lang=1&cs-lang=fsharp)
Note