StackTrace Klas

Definitie

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.

Van toepassing op

Zie ook