Ler em inglês

Compartilhar via


StackTrace Classe

Definição

Representa um rastreamento de pilha, que é uma coleção ordenada de um ou mais registros de ativação.

C#
public sealed class StackTrace
C#
public class StackTrace
C#
[System.Serializable]
public class StackTrace
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public class StackTrace
Herança
StackTrace
Atributos

Exemplos

O aplicativo de console a seguir demonstra como criar um simples StackTrace e iterar por meio de seus quadros para obter informações de depuração e diagnóstico.

C#
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

*/

Comentários

StackTrace as informações serão mais informativas com as configurações de build de depuração. Por padrão, os builds de depuração incluem símbolos de depuração, enquanto os builds de versão não. Os símbolos de depuração contêm a maioria das informações de arquivo, nome do método, número de linha e coluna usadas na construção StackFrame de objetos e StackTrace .

StackTrace pode não relatar quantas chamadas de método forem esperadas, devido a transformações de código que ocorrem durante a otimização.

Construtores

StackTrace()

Inicializa uma nova instância da classe StackTrace do quadro do chamador.

StackTrace(Boolean)

Inicializa uma nova instância da classe StackTrace do quadro do chamador, capturando originalmente as informações de origem.

StackTrace(Exception)

Inicializa uma nova instância da classe StackTrace usando o objeto de exceção fornecido.

StackTrace(Exception, Boolean)

Inicializa uma nova instância da classe StackTrace, usando o objeto de exceção fornecido e, opcionalmente, capturando as informações de origem.

StackTrace(Exception, Int32)

Inicializa uma nova instância da classe StackTrace, usando o objeto de exceção fornecido e ignorando o número especificado de quadros.

StackTrace(Exception, Int32, Boolean)

Inicializa uma nova instância da classe StackTrace usando o objeto de exceção fornecido, ignorando o número especificado de quadros e, opcionalmente, capturando informações de origem.

StackTrace(IEnumerable<StackFrame>)

Constrói um rastreamento de pilha de um conjunto de StackFrame objetos.

StackTrace(Int32)

Inicializa uma nova instância da classe StackTrace com base no quadro do chamador, ignorando o número de quadros especificado.

StackTrace(Int32, Boolean)

Inicializa uma nova instância da classe StackTrace com base no quadro do chamador, ignorando o número especificado de quadros e, opcionalmente, capturando informações de origem.

StackTrace(StackFrame)

Inicializa uma nova instância da classe StackTrace que contém um único quadro.

StackTrace(Thread, Boolean)
Obsoleto.

Inicializa uma nova instância da classe StackTrace para um thread específico, com a opção de capturar informações de origem.

Não usar essa sobrecarga de construtor.

Campos

METHODS_TO_SKIP

Define o padrão para o número de métodos a ser omitido do rastreamento de pilha. Este campo é constante.

Propriedades

FrameCount

Obtém o número de quadros no rastreamento da pilha.

Métodos

Equals(Object)

Determina se o objeto especificado é igual ao objeto atual.

(Herdado de Object)
GetFrame(Int32)

Obtém o registro de ativação especificado.

GetFrames()

Retorna uma cópia de todos os quadros de pilha no rastreamento de pilha atual.

GetHashCode()

Serve como a função de hash padrão.

(Herdado de Object)
GetType()

Obtém o Type da instância atual.

(Herdado de Object)
MemberwiseClone()

Cria uma cópia superficial do Object atual.

(Herdado de Object)
ToString()

Cria uma representação legível do rastreamento de pilha.

Aplica-se a

Produto Versões
.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
UWP 10.0

Confira também