StackTrace Klas
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Vertegenwoordigt een stack-trace, dit is een geordende verzameling van een of meer stackframes.
public ref class StackTrace sealed
public ref class StackTrace
public sealed class StackTrace
[System.Serializable]
public class StackTrace
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public class StackTrace
public class StackTrace
type StackTrace = class
[<System.Serializable>]
type StackTrace = class
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type StackTrace = class
Public NotInheritable Class StackTrace
Public Class StackTrace
- Overname
-
StackTrace
- Kenmerken
Voorbeelden
In de volgende consoletoepassing ziet u hoe u een eenvoudig StackTrace en doorlopend kader maakt om foutopsporing en diagnostische gegevens te verkrijgen.
using System;
using System.Diagnostics;
class StackTraceSample
{
[STAThread]
static void Main(string[] args)
{
StackTraceSample sample = new StackTraceSample();
try
{
sample.MyPublicMethod();
}
catch (Exception)
{
// Create a StackTrace that captures
// filename, line number, and column
// information for the current thread.
StackTrace st = new StackTrace(true);
for(int i =0; i< st.FrameCount; i++ )
{
// Note that high up the call stack, there is only
// one stack frame.
StackFrame sf = st.GetFrame(i);
Console.WriteLine();
Console.WriteLine("High up the call stack, Method: {0}",
sf.GetMethod());
Console.WriteLine("High up the call stack, Line Number: {0}",
sf.GetFileLineNumber());
}
}
}
public void MyPublicMethod ()
{
MyProtectedMethod();
}
protected void MyProtectedMethod ()
{
MyInternalClass mic = new MyInternalClass();
mic.ThrowsException();
}
class MyInternalClass
{
public void ThrowsException()
{
try
{
throw new Exception("A problem was encountered.");
}
catch (Exception e)
{
// Create a StackTrace that captures filename,
// line number and column information.
StackTrace st = new StackTrace(true);
string stackIndent = "";
for(int i =0; i< st.FrameCount; i++ )
{
// Note that at this level, there are four
// stack frames, one for each method invocation.
StackFrame sf = st.GetFrame(i);
Console.WriteLine();
Console.WriteLine(stackIndent + " Method: {0}",
sf.GetMethod() );
Console.WriteLine( stackIndent + " File: {0}",
sf.GetFileName());
Console.WriteLine( stackIndent + " Line Number: {0}",
sf.GetFileLineNumber());
stackIndent += " ";
}
throw e;
}
}
}
}
/*
This console application produces the following output when
compiled with the Debug configuration.
Method: Void ThrowsException()
File: c:\samples\stacktraceframe\myclass.cs
Line Number: 59
Method: Void MyProtectedMethod()
File: c:\samples\stacktraceframe\myclass.cs
Line Number: 45
Method: Void MyPublicMethod()
File: c:\samples\stacktraceframe\myclass.cs
Line Number: 39
Method: Void Main(System.String[])
File: c:\samples\stacktraceframe\myclass.cs
Line Number: 13
High up the call stack, Method: Void Main(System.String[])
High up the call stack, Line Number: 20
This console application produces the following output when
compiled with the Release configuration.
Method: Void ThrowsException()
File:
Line Number: 0
Method: Void Main(System.String[])
File:
Line Number: 0
High up the call stack, Method: Void Main(System.String[])
High up the call stack, Line Number: 0
*/
Imports System.Diagnostics
Class StackTraceSample
<STAThread()> _
Public Shared Sub Main()
Dim sample As New StackTraceSample()
Try
sample.MyPublicMethod()
Catch
' Create a StackTrace that captures
' filename, line number, and column
' information for the current thread.
Dim st As New StackTrace(True)
Dim i As Integer
For i = 0 To st.FrameCount - 1
' Note that high up the call stack, there is only
' one stack frame.
Dim sf As StackFrame = st.GetFrame(i)
Console.WriteLine()
Console.WriteLine("High up the call stack, Method: {0}", _
sf.GetMethod())
Console.WriteLine("High up the call stack, Line Number: {0}", _
sf.GetFileLineNumber())
Next i
End Try
End Sub
Public Sub MyPublicMethod()
MyProtectedMethod()
End Sub
Protected Sub MyProtectedMethod()
Dim mic As New MyInternalClass()
mic.ThrowsException()
End Sub
Class MyInternalClass
Public Sub ThrowsException()
Try
Throw New Exception("A problem was encountered.")
Catch e As Exception
' Create a StackTrace that captures filename,
' line number and column information.
Dim st As New StackTrace(True)
Dim stackIndent As String = ""
Dim i As Integer
For i = 0 To st.FrameCount - 1
' Note that at this level, there are four
' stack frames, one for each method invocation.
Dim sf As StackFrame = st.GetFrame(i)
Console.WriteLine()
Console.WriteLine(stackIndent + " Method: {0}", _
sf.GetMethod())
Console.WriteLine(stackIndent + " File: {0}", _
sf.GetFileName())
Console.WriteLine(stackIndent + " Line Number: {0}", _
sf.GetFileLineNumber())
stackIndent += " "
Next i
Throw e
End Try
End Sub
End Class
End Class
' This console application produces the following output when
' compiled with the Debug configuration.
'
' Method: Void ThrowsException()
' File: c:\pp\samples\stacktraceframe\myclass.vb
' Line Number: 55
'
' Method: Void MyProtectedMethod()
' File: c:\pp\samples\stacktraceframe\myclass.vb
' Line Number: 42
'
' Method: Void MyPublicMethod()
' File: c:\pp\samples\stacktraceframe\myclass.vb
' Line Number: 37
'
' Method: Void Main(System.String[])
' File: c:\pp\samples\stacktraceframe\myclass.vb
' Line Number: 13
'
' High up the call stack, Method: Void Main(System.String[])
' High up the call stack, Line Number: 18
'
'
' This console application produces the following output when
' compiled with the Release configuration.
'
' Method: Void ThrowsException()
' File:
' Line Number: 0
'
' Method: Void Main(System.String[])
' File:
' Line Number: 0
'
' High up the call stack, Method: Void Main()
' High up the call stack, Line Number: 0
'
Opmerkingen
StackTrace informatie is het meest informatief met buildconfiguraties voor foutopsporing. Foutopsporingsversies bevatten standaard foutopsporingssymbolen, terwijl release-builds dat niet doen. De foutopsporingssymbolen bevatten de meeste bestands-, methodenaam-, regelnummer- en kolomgegevens die worden gebruikt bij het StackFrame samenstellen en StackTrace objecten.
StackTrace rapporteert mogelijk niet zoveel methode-aanroepen als verwacht, vanwege codetransformaties die plaatsvinden tijdens optimalisatie.
Constructors
| Name | Description |
|---|---|
| StackTrace() |
Initialiseert een nieuw exemplaar van de StackTrace klasse vanuit het frame van de beller. |
| StackTrace(Boolean) |
Initialiseert een nieuw exemplaar van de StackTrace klasse vanuit het frame van de aanroeper, optioneel het vastleggen van brongegevens. |
| StackTrace(Exception, Boolean) |
Initialiseert een nieuw exemplaar van de StackTrace klasse met behulp van het opgegeven uitzonderingsobject en optioneel het vastleggen van brongegevens. |
| StackTrace(Exception, Int32, Boolean) |
Initialiseert een nieuw exemplaar van de StackTrace klasse met behulp van het opgegeven uitzonderingsobject, waarbij het opgegeven aantal frames wordt overgeslagen en eventueel brongegevens worden vastgelegd. |
| StackTrace(Exception, Int32) |
Initialiseert een nieuw exemplaar van de StackTrace klasse met behulp van het opgegeven uitzonderingsobject en overslaat het opgegeven aantal frames. |
| StackTrace(Exception) |
Initialiseert een nieuw exemplaar van de StackTrace klasse met behulp van het opgegeven uitzonderingsobject. |
| StackTrace(Int32, Boolean) |
Initialiseert een nieuw exemplaar van de StackTrace klasse vanuit het frame van de aanroeper, waarbij het opgegeven aantal frames wordt overgeslagen en eventueel brongegevens worden vastgelegd. |
| StackTrace(Int32) |
Initialiseert een nieuw exemplaar van de StackTrace klasse vanuit het frame van de aanroeper, waarbij het opgegeven aantal frames wordt overgeslagen. |
| StackTrace(StackFrame) |
Initialiseert een nieuw exemplaar van de StackTrace klasse die één frame bevat. |
| StackTrace(Thread, Boolean) |
Verouderd.
Initialiseert een nieuw exemplaar van de StackTrace klasse voor een specifieke thread, optioneel het vastleggen van brongegevens. Gebruik deze constructoroverbelasting niet. |
Velden
| Name | Description |
|---|---|
| METHODS_TO_SKIP |
Definieert de standaardwaarde voor het aantal methoden dat moet worden weggelaten uit de stack-trace. Dit veld is constant. |
Eigenschappen
| Name | Description |
|---|---|
| FrameCount |
Hiermee haalt u het aantal frames op in de stack-trace. |
Methoden
| Name | Description |
|---|---|
| Equals(Object) |
Bepaalt of het opgegeven object gelijk is aan het huidige object. (Overgenomen van Object) |
| GetFrame(Int32) |
Hiermee haalt u het opgegeven stackframe op. |
| GetFrames() |
Retourneert een kopie van alle stackframes in de huidige stacktracering. |
| GetHashCode() |
Fungeert als de standaardhashfunctie. (Overgenomen van Object) |
| GetType() |
Hiermee haalt u de Type huidige instantie op. (Overgenomen van Object) |
| MemberwiseClone() |
Hiermee maakt u een ondiepe kopie van de huidige Object. (Overgenomen van Object) |
| ToString() |
Hiermee wordt een leesbare weergave van de stacktracering gebouwd. |