Logging Exceptions in C# | Practical Examples

Explore practical examples of logging exceptions in C#. Learn how to implement effective error handling.
By Jamie

Introduction to Logging Exceptions in C

In software development, handling exceptions is crucial for maintaining the stability and reliability of applications. Logging exceptions provides developers with insight into errors that occur in their programs, enabling them to diagnose and resolve issues efficiently. In this article, we will explore three practical examples of logging exceptions in C#, highlighting different contexts and use cases.

Example 1: Basic Exception Logging with Console

In this example, we will demonstrate a simple approach for logging exceptions using the console output. This method is useful for debugging during development and can be easily extended to log to files or external systems later.

Imagine a scenario where we have a method that performs division operations. If a division by zero occurs, we need to log that exception.

using System;

class Program
{
    static void Main(string[] args)
    {
        try
        {
            int result = Divide(10, 0);
            Console.WriteLine("Result: " + result);
        }
        catch (DivideByZeroException ex)
        {
            Console.WriteLine("Error: " + ex.Message);
        }
    }

    static int Divide(int numerator, int denominator)
    {
        return numerator / denominator;
    }
}

In this code snippet, when we attempt to divide by zero, a DivideByZeroException is thrown. The catch block captures the exception and logs the error message to the console.

Notes

  • This is a basic example suitable for debugging during development.
  • In production, consider using a logging framework instead of Console.WriteLine for better logging management.

Example 2: Logging Exceptions to a File

For applications that require persistent logging, writing exceptions to a file is a common practice. This example illustrates how to log exceptions to a text file, which can be useful for later analysis.

Suppose we have a method that reads data from a file. If the file does not exist, we need to log this exception.

using System;
using System.IO;

class FileLogger
{
    private const string logFilePath = "error.log";

    static void Main(string[] args)
    {
        try
        {
            ReadDataFromFile("data.txt");
        }
        catch (FileNotFoundException ex)
        {
            LogException(ex);
        }
    }

    static void ReadDataFromFile(string fileName)
    {
        using (StreamReader sr = new StreamReader(fileName))
        {
            string content = sr.ReadToEnd();
            Console.WriteLine(content);
        }
    }

    static void LogException(Exception ex)
    {
        using (StreamWriter sw = new StreamWriter(logFilePath, true))
        {
            sw.WriteLine($"{DateTime.Now}: {ex.Message}");
        }
    }
}

In this example, when the ReadDataFromFile method attempts to access a non-existent file, a FileNotFoundException is thrown. The LogException method captures the error and appends it to a log file named error.log.

Notes

  • Ensure proper file permissions when writing to files.
  • You can enhance the logging by including stack traces or additional context.

Example 3: Using a Logging Framework (NLog)

When developing larger applications, using a logging framework can significantly improve the logging process. In this example, we will use NLog, a popular logging framework for .NET applications, to log exceptions.

Let’s assume we have a web application that processes user input. If an error occurs while processing the input, we want to log it using NLog.

using System;
using NLog;

class Program
{
    private static readonly Logger logger = LogManager.GetCurrentClassLogger();

    static void Main(string[] args)
    {
        try
        {
            ProcessUserInput(null);
        }
        catch (ArgumentNullException ex)
        {
            logger.Error(ex, "An error occurred while processing user input.");
        }
    }

    static void ProcessUserInput(string input)
    {
        if (string.IsNullOrEmpty(input))
        {
            throw new ArgumentNullException(nameof(input), "Input cannot be null or empty.");
        }
        // Process input...
    }
}

In this case, when ProcessUserInput is called with a null value, an ArgumentNullException is thrown. The NLog framework captures this exception and logs it with a detailed error message.

Notes

  • NLog allows for flexible configurations, such as logging to various targets (e.g., console, file, database).
  • Consider adding more contextual information to your logs for better traceability.

Conclusion

Logging exceptions in C# is essential for effective error handling and debugging. By implementing structured logging methods—whether through console output, file logging, or using a logging framework like NLog—you can improve the maintainability and reliability of your applications.