Как распечатать полную трассировку стека в исключении? - PullRequest
83 голосов
/ 25 ноября 2010

Например, в одном месте ...

//---------------a
try
{
    // some network call
}
catch(WebException we)
{
    throw new MyCustomException("some message ....", we);
}

... и в другом месте ...

//--------------b
try
{
    // invoke code above
}
catch(MyCustomException we)
{
    Debug.Writeline(we.stacktrace);   // <----------------
}

Трассировка стека, которую я печатаю, она начинается только с a по b, он не включает внутреннюю трассировку стека из WebException.

Как мне распечатать всю трассировку стека ???

Ответы [ 3 ]

153 голосов
/ 25 ноября 2010

Я обычно использую метод .ToString () для исключений, чтобы представить полную информацию об исключениях (включая трассировку внутреннего стека) в тексте:

catch (MyCustomException ex)
{
    Debug.Writeline(ex.ToString());
}

Пример вывода:

ConsoleApplication1.MyCustomException: some message .... ---> System.Exception: Oh noes!
   at ConsoleApplication1.SomeObject.OtherMethod() in C:\ConsoleApplication1\SomeObject.cs:line 24
   at ConsoleApplication1.SomeObject..ctor() in C:\ConsoleApplication1\SomeObject.cs:line 14
   --- End of inner exception stack trace ---
   at ConsoleApplication1.SomeObject..ctor() in C:\ConsoleApplication1\SomeObject.cs:line 18
   at ConsoleApplication1.Program.DoSomething() in C:\ConsoleApplication1\Program.cs:line 23
   at ConsoleApplication1.Program.Main(String[] args) in C:\ConsoleApplication1\Program.cs:line 13
51 голосов
/ 25 ноября 2010

Используйте функцию, подобную этой:

    public static string FlattenException(Exception exception)
    {
        var stringBuilder = new StringBuilder();

        while (exception != null)
        {
            stringBuilder.AppendLine(exception.Message);
            stringBuilder.AppendLine(exception.StackTrace);

            exception = exception.InnerException;
        }

        return stringBuilder.ToString();
    }

Тогда вы можете назвать это так:

try
{
    // invoke code above
}
catch(MyCustomException we)
{
    Debug.Writeline(FlattenException(we));
}
11 голосов
/ 05 апреля 2017

Если вы передадите свое исключение следующей функции, она предоставит вам все методы и детали, которые являются причинами исключения.

public string GetAllFootprints(Exception x)
{
        var st = new StackTrace(x, true);
        var frames = st.GetFrames();
        var traceString = new StringBuilder();

        foreach (var frame in frames)
        {
            if (frame.GetFileLineNumber() < 1)
                continue;

            traceString.Append("File: " + frame.GetFileName());
            traceString.Append(", Method:" + frame.GetMethod().Name);
            traceString.Append(", LineNumber: " + frame.GetFileLineNumber());
            traceString.Append("  -->  ");
        }

        return traceString.ToString();
}

Результат:

Файл: c: \ MyProject \ Program.cs, метод: MyFunction, номер строки: 29 ->
Файл: c: \ MyProject \ Program.cs, метод: Main, номер строки: 16 ->

...