Feedback

C# - Methode, Datei und Zeilennummer einer Exception bestimmen

Veröffentlicht von am 25.01.2019
(0 Bewertungen)
Tritt eine Exception auf, muss man als Entwickler meist einen langen Stack-Trace lesen.
Möchte man zum Beispiel die „Hard-Facts“ einer größeren Anwendung für Statistikzwecke in einer Datenbank strukturiert ablegen, benötigt man Möglichkeiten an die Datei, die Methode und die Zeilennummer heran zu kommen.
Im .NET-Framework gibt es hierzu hilfreiche Methoden wie das folgende Snippet demonstriert.
Die Ausgabe auf der Konsole wäre für dieses Snippet:

Exception message: Exception of type 'System.Exception' was thrown.
Exception in file: D:\Users\t14011a\source\repos\ConsoleApp1\ConsoleApp1\Program.cs
Exception in method: Void Main(System.String[])
Exception at line numer: 12

GFU-Schulungen  [Anzeige]

ASP.NET Core Server- und Client-Programmierung

Sie  lernen in drei (3) Tagen wie man mit  ASP.NET Core und den Technologien  MVC, Entity Framework, WebAPI und  Razor professionelle sowie moderne  Web-Anwendungsarchitekturen aufbaut.  Die Schulung ist der perfekte  Einstieg um insbesondere datengetriebene  und präsentationsorientierte  Applikationen auf Basis der robusten und  skalierbaren ASP.NET Core  Plattform zu erstellen. Nach der Veranstaltung kennen Sie die Konzepte von Angular und können Angular in neue und bestehende ASP.NET-Anwendungen einsetzen.

C# 2017/2015/2013 Grundlagen

Nach Abschluss des Kurses sind Ihnen die Datentypen und Klassenbibliotheken von C# bekannt. Außerdem sind Sie in der Lage, mit Variablen umzugehen und deren Typen zu konvertieren. Sie definieren Namespaces und setzen diese ein, Sie erstellen eigene Klassen  und bauen Trouble Shooting ein.

using System;
using System.Diagnostics;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            try
            {
                throw new Exception();
            }
            catch (Exception ex)
            {
                var stackTrace = new StackTrace(ex, true);
                var frame = stackTrace.GetFrame(0);
                
                Console.WriteLine("Exception message: {0}", ex.Message);
                Console.WriteLine("Exception in file: {0}", frame.GetFileName());
                Console.WriteLine("Exception in method: {0}", frame.GetMethod());
                Console.WriteLine("Exception at line numer: {0}", frame.GetFileLineNumber());

                Console.Read();
            }
        }
    }
}

Abgelegt unter exception.

Kommentare zum Snippet

 

Logge dich ein, um hier zu kommentieren!