Trace.WriteIf 方法
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
如果條件 true
,請將追蹤的相關信息寫入至 Listeners 集合中的追蹤接聽程式。
WriteIf(Boolean, String, String) |
如果條件 |
WriteIf(Boolean, Object, String) |
如果條件是 |
WriteIf(Boolean, Object) |
如果條件是 |
WriteIf(Boolean, String) |
如果條件 |
- 來源:
- Trace.cs
- 來源:
- Trace.cs
- 來源:
- Trace.cs
如果條件 true
,請將類別名稱和訊息寫入 Listeners 集合中的追蹤接聽程式。
public:
static void WriteIf(bool condition, System::String ^ message, System::String ^ category);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, string? message, string? category);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, string message, string category);
[<System.Diagnostics.Conditional("TRACE")>]
static member WriteIf : bool * string * string -> unit
Public Shared Sub WriteIf (condition As Boolean, message As String, category As String)
參數
- condition
- Boolean
true
造成訊息寫入;否則,false
。
- message
- String
要寫入的訊息。
- category
- String
用來組織輸出的類別名稱。
- 屬性
範例
下列範例會建立名為 generalSwitch
TraceSwitch。 此參數是在程式代碼范例外部設定。
如果 參數設定為 TraceLevelVerbose
,則此範例會將第一個錯誤訊息輸出至 Listeners。 如需將接聽程式新增至 Listeners 集合的詳細資訊,請參閱 TraceListenerCollection 類別。
然後,如果 TraceLevel 設定為 Error
或更新版本,則此範例會在與第一則訊息相同的行上輸出第二個錯誤訊息。 第二則訊息後面接著行終止符。
// Class-level declaration.
// Create a TraceSwitch.
private:
static TraceSwitch^ generalSwitch =
gcnew TraceSwitch( "General", "Entire Application" );
public:
static void MyErrorMethod( Object^ myObject, String^ category )
{
#if defined(TRACE)
// Write the message if the TraceSwitch level is set to Verbose.
Trace::WriteIf( generalSwitch->TraceVerbose,
String::Concat( myObject,
" is not a valid object for category: " ), category );
// Write a second message if the TraceSwitch level is set
// to Error or higher.
Trace::WriteLineIf( generalSwitch->TraceError,
" Please use a different category." );
#endif
}
// Class-level declaration.
// Create a TraceSwitch.
static TraceSwitch generalSwitch = new TraceSwitch("General", "Entire Application");
static public void MyErrorMethod(Object myObject, string category) {
// Write the message if the TraceSwitch level is set to Verbose.
Trace.WriteIf(generalSwitch.TraceVerbose, myObject.ToString() +
" is not a valid object for category: ", category);
// Write a second message if the TraceSwitch level is set to Error or higher.
Trace.WriteLineIf(generalSwitch.TraceError, " Please use a different category.");
}
' Class-level declaration.
' Create a TraceSwitch.
Private Shared generalSwitch As New TraceSwitch("General", "Entire Application")
Public Shared Sub MyErrorMethod(myObject As Object, category As String)
' Write the message if the TraceSwitch level is set to Verbose.
Trace.WriteIf(generalSwitch.TraceVerbose, myObject.ToString() & _
" is not a valid object for category: ", category)
' Write a second message if the TraceSwitch level is set to Error or higher.
Trace.WriteLineIf(generalSwitch.TraceError, _
" Please use a different category.")
End Sub
備註
根據預設,輸出會寫入 DefaultTraceListener實例。
category
參數可用來將輸出訊息分組。
這個方法會呼叫追蹤接聽程式的 Write 方法。
給繼承者的注意事項
您可以使用 If...Then
語句,而不是使用 WriteIf(Boolean, String) 語句,將檢測應用程式的效能降低到最低。 下列兩個程式代碼範例會傳送相同的偵錯訊息。 不過,當追蹤關閉時,第一個範例會更快,因為如果 mySwitch.TraceError
評估為 false
您不會呼叫 Write(String)。 第二個範例一律會呼叫 WriteIf(Boolean, String),即使 mySwitch.TraceError
false
,也不會產生追蹤輸出。 這可能會導致不必要地執行任意複雜的程序代碼。
第一個範例
if(mySwitch.TraceError)
Trace.Write("aNumber = " + aNumber + " out of range");
第二個範例
Trace.WriteIf(mySwitch.TraceError, "aNumber = " + aNumber + " out of range");
另請參閱
適用於
.NET 9 及其他版本
產品 | 版本 |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 2.0, 2.1 |
- 來源:
- Trace.cs
- 來源:
- Trace.cs
- 來源:
- Trace.cs
如果條件是 true
,請將物件的 ToString() 方法的類別名稱和值寫入至 Listeners 集合中的追蹤接聽程式。
public:
static void WriteIf(bool condition, System::Object ^ value, System::String ^ category);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, object? value, string? category);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, object value, string category);
[<System.Diagnostics.Conditional("TRACE")>]
static member WriteIf : bool * obj * string -> unit
Public Shared Sub WriteIf (condition As Boolean, value As Object, category As String)
參數
- condition
- Boolean
true
造成訊息寫入;否則,false
。
- category
- String
用來組織輸出的類別名稱。
- 屬性
範例
下列範例會建立名為 generalSwitch
TraceSwitch。 此參數是在程式代碼范例外部設定。
如果 參數設定為 TraceLevelVerbose
,則此範例會將 myObject
的名稱和 category
輸出至 Listeners。 如需將接聽程式新增至 Listeners 集合的詳細資訊,請參閱 TraceListenerCollection 類別。
然後,如果 TraceLevel 設定為 Error
或更新版本,則此範例會在與第一則訊息相同的行上輸出第二個錯誤訊息。 第二則訊息後面接著行終止符。
// Class-level declaration.
// Create a TraceSwitch.
private:
static TraceSwitch^ generalSwitch =
gcnew TraceSwitch( "General", "Entire Application" );
public:
static void MyErrorMethod( Object^ myObject, String^ category )
{
#if defined(TRACE)
// Write the message if the TraceSwitch level is set to Verbose.
Trace::WriteIf( generalSwitch->TraceVerbose, myObject, category );
// Write a second message if the TraceSwitch level is set to
// Error or higher.
Trace::WriteLineIf( generalSwitch->TraceError,
" Object is not valid for this category." );
#endif
}
// Class-level declaration.
// Create a TraceSwitch.
static TraceSwitch generalSwitch = new TraceSwitch("General", "Entire Application");
static public void MyErrorMethod(Object myObject, string category) {
// Write the message if the TraceSwitch level is set to Verbose.
Trace.WriteIf(generalSwitch.TraceVerbose, myObject, category);
// Write a second message if the TraceSwitch level is set to Error or higher.
Trace.WriteLineIf(generalSwitch.TraceError, " Object is not valid for this category.");
}
' Class-level declaration.
' Create a TraceSwitch.
Private Shared generalSwitch As New TraceSwitch("General", "Entire Application")
Public Shared Sub MyErrorMethod(myObject As Object, category As String)
' Write the message if the TraceSwitch level is set to Verbose.
Trace.WriteIf(generalSwitch.TraceVerbose, myObject, category)
' Write a second message if the TraceSwitch level is set to Error or higher.
Trace.WriteLineIf(generalSwitch.TraceError, _
" Object is not valid for this category.")
End Sub
備註
根據預設,輸出會寫入 DefaultTraceListener實例。
category
參數可用來將輸出訊息分組。
這個方法會呼叫追蹤接聽程式的 Write 方法。
給繼承者的注意事項
您可以使用 If...Then
語句,而不是使用 WriteIf(Boolean, String) 語句,將檢測應用程式的效能降低到最低。 下列兩個程式代碼範例會傳送相同的偵錯訊息。 不過,當追蹤關閉時,第一個範例會更快,因為如果 mySwitch.TraceError
評估為 false
您不會呼叫 Write(String)。 第二個範例一律會呼叫 WriteIf(Boolean, String),即使 mySwitch.TraceError
false
,也不會產生追蹤輸出。 這可能會導致不必要地執行任意複雜的程序代碼。
第一個範例
if(mySwitch.TraceError)
Trace.Write("aNumber = " + aNumber + " out of range");
第二個範例
Trace.WriteIf(mySwitch.TraceError, "aNumber = " + aNumber + " out of range");
另請參閱
適用於
.NET 9 及其他版本
產品 | 版本 |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 2.0, 2.1 |
- 來源:
- Trace.cs
- 來源:
- Trace.cs
- 來源:
- Trace.cs
如果條件是 true
,請將物件的 ToString() 方法值寫入 Listeners 集合中的追蹤接聽項。
public:
static void WriteIf(bool condition, System::Object ^ value);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, object? value);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, object value);
[<System.Diagnostics.Conditional("TRACE")>]
static member WriteIf : bool * obj -> unit
Public Shared Sub WriteIf (condition As Boolean, value As Object)
參數
- condition
- Boolean
true
造成訊息寫入;否則,false
。
- 屬性
範例
下列範例會建立名為 generalSwitch
TraceSwitch。 此參數是在程式代碼范例外部設定。
如果參數設定為 TraceLevelError
或更高版本,則範例會將 value 參數的第一個名稱輸出至 Listeners。 如需將接聽程式新增至 Listeners 集合的詳細資訊,請參閱 TraceListenerCollection 類別。
然後,如果 TraceLevel 設定為 Verbose
,則此範例會在與第一個訊息相同的行上輸出訊息。 第二則訊息後面接著行終止符。
// Class-level declaration.
// Create a TraceSwitch.
private:
static TraceSwitch^ generalSwitch =
gcnew TraceSwitch( "General", "Entire Application" );
public:
static void MyErrorMethod( Object^ myObject )
{
#if defined(TRACE)
// Write the message if the TraceSwitch level is set
// to Error or higher.
Trace::WriteIf( generalSwitch->TraceError, myObject );
// Write a second message if the TraceSwitch level is set
// to Verbose.
Trace::WriteLineIf( generalSwitch->TraceVerbose,
" is not a valid value for this method." );
#endif
}
// Class-level declaration.
// Create a TraceSwitch.
static TraceSwitch generalSwitch = new TraceSwitch("General", "Entire Application");
static public void MyErrorMethod(Object myObject) {
// Write the message if the TraceSwitch level is set to Error or higher.
Trace.WriteIf(generalSwitch.TraceError, myObject);
// Write a second message if the TraceSwitch level is set to Verbose.
Trace.WriteLineIf(generalSwitch.TraceVerbose, " is not a valid value for this method.");
}
' Class-level declaration.
' Create a TraceSwitch.
Private Shared generalSwitch As New TraceSwitch("General", "Entire Application")
Public Shared Sub MyErrorMethod(myObject As Object)
' Write the message if the TraceSwitch level is set to Error or higher.
Trace.WriteIf(generalSwitch.TraceError, myObject)
' Write a second message if the TraceSwitch level is set to Verbose.
Trace.WriteLineIf(generalSwitch.TraceVerbose, _
" is not a valid value for this method.")
End Sub
備註
根據預設,輸出會寫入 DefaultTraceListener實例。
這個方法會呼叫追蹤接聽程式的 Write 方法。
給繼承者的注意事項
您可以使用 If...Then
語句,而不是使用 WriteIf(Boolean, String) 語句,將檢測應用程式的效能降低到最低。 下列兩個程式代碼範例會傳送相同的偵錯訊息。 不過,當追蹤關閉時,第一個範例會更快,因為如果 mySwitch.TraceError
評估為 false
您不會呼叫 Write(String)。 第二個範例一律會呼叫 WriteIf(Boolean, String),即使 mySwitch.TraceError
false
,也不會產生追蹤輸出。 這可能會導致不必要地執行任意複雜的程序代碼。
第一個範例
if(mySwitch.TraceError)
Trace.Write("aNumber = " + aNumber + " out of range");
第二個範例
Trace.WriteIf(mySwitch.TraceError, "aNumber = " + aNumber + " out of range");
另請參閱
適用於
.NET 9 及其他版本
產品 | 版本 |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 2.0, 2.1 |
- 來源:
- Trace.cs
- 來源:
- Trace.cs
- 來源:
- Trace.cs
如果條件 true
,請將訊息寫入 Listeners 集合中的追蹤接聽程式。
public:
static void WriteIf(bool condition, System::String ^ message);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, string? message);
[System.Diagnostics.Conditional("TRACE")]
public static void WriteIf (bool condition, string message);
[<System.Diagnostics.Conditional("TRACE")>]
static member WriteIf : bool * string -> unit
Public Shared Sub WriteIf (condition As Boolean, message As String)
參數
- condition
- Boolean
true
造成訊息寫入;否則,false
。
- message
- String
要寫入的訊息。
- 屬性
範例
下列範例會建立名為 generalSwitch
TraceSwitch。 此參數是在程式代碼范例外部設定。
如果參數設定為 TraceLevelError
或更高版本,則此範例會將第一個錯誤訊息輸出至 Listeners。 如需將接聽程式新增至 Listeners 集合的詳細資訊,請參閱 TraceListenerCollection 類別。
然後,如果 TraceLevel 設定為 Verbose
,則此範例會在與第一個訊息相同的行上輸出第二個錯誤訊息。 第二則訊息後面接著行終止符。
// Class-level declaration.
// Create a TraceSwitch.
private:
static TraceSwitch^ generalSwitch =
gcnew TraceSwitch( "General", "Entire Application" );
public:
static void MyErrorMethod()
{
#if defined(TRACE)
// Write the message if the TraceSwitch level is set to
// Error or higher.
Trace::WriteIf( generalSwitch->TraceError, "My error message. " );
// Write a second message if the TraceSwitch level is set
// to Verbose.
Trace::WriteLineIf( generalSwitch->TraceVerbose,
"My second error message." );
#endif
}
// Class-level declaration.
// Create a TraceSwitch.
static TraceSwitch generalSwitch = new TraceSwitch("General", "Entire Application");
static public void MyErrorMethod() {
// Write the message if the TraceSwitch level is set to Error or higher.
Trace.WriteIf(generalSwitch.TraceError, "My error message. ");
// Write a second message if the TraceSwitch level is set to Verbose.
Trace.WriteLineIf(generalSwitch.TraceVerbose, "My second error message.");
}
' Class-level declaration.
' Create a TraceSwitch.
Private Shared generalSwitch As New TraceSwitch("General", "Entire Application")
Public Shared Sub MyErrorMethod()
' Write the message if the TraceSwitch level is set to Error or higher.
Trace.WriteIf(generalSwitch.TraceError, "My error message. ")
' Write a second message if the TraceSwitch level is set to Verbose.
Trace.WriteLineIf(generalSwitch.TraceVerbose, "My second error message.")
End Sub
備註
根據預設,輸出會寫入 DefaultTraceListener實例。
這個方法會呼叫追蹤接聽程式的 Write 方法。
給繼承者的注意事項
您可以使用 If...Then
語句,而不是使用 WriteIf(Boolean, String) 語句,將檢測應用程式的效能降低到最低。 下列兩個程式代碼範例會傳送相同的偵錯訊息。 不過,當追蹤關閉時,第一個範例會更快,因為如果 mySwitch.TraceError
評估為 false
您不會呼叫 Write(String)。 第二個範例一律會呼叫 WriteIf(Boolean, String),即使 mySwitch.TraceError
false
,也不會產生追蹤輸出。 這可能會導致不必要地執行任意複雜的程序代碼。
第一個範例
if(mySwitch.TraceError)
Trace.Write("aNumber = " + aNumber + " out of range");
第二個範例
Trace.WriteIf(mySwitch.TraceError, "aNumber = " + aNumber + " out of range");
另請參閱
適用於
.NET 9 及其他版本
產品 | 版本 |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 2.0, 2.1 |