c# exception questions

208 Views Asked by At

Thank you all for helping.

This code doesn't produce what I expect when the divisor is 1. The base class for ExceptOne doesn't get called, the hyperlink in ExceptOne doesn't get displayed. What am I missing ?!

Console output is:

enter a divisor
1
WriteLine exception 1...
WriteLine exception 2...
base ctor2
http : // exc2.com
Writeline in finally

class Program
{
    static void Main(string[] args)
    {
        try
        {
            byte y = 0;
            byte x = 10;
            Console.WriteLine("enter a divisor");
            string s = (Console.ReadLine());
            y = Convert.ToByte(s);
            if (y == 1) throw new ExceptOne();
            Console.WriteLine("result is {0}", x / y); ;
        }

        catch (System.DivideByZeroException e)
        {
            Console.WriteLine("exception occured {0}...", e.Message);
        }

        catch (ExceptOne p)
        {
            Console.WriteLine(p.Message +"\n"+ p.HelpLink);

        }

        catch (System.Exception r)
        {
            Console.WriteLine(r.Message + "\n" + r.HelpLink);
        }

        finally
        {
            Console.WriteLine("Writeline in finally ");
            Console.ReadLine();
        }
    }
}

public class ExceptOne : System.Exception
{
    public ExceptOne()
        : base("base ctor 1 ")
    {
        this.HelpLink = "http://exc1.com";
        Console.WriteLine("WriteLine exception 1...");
        throw new Exception2();
    }
}

public class Exception2 : System.Exception
{
    public Exception2()
        : base("base ctor2 ")
    {
        Console.WriteLine("WriteLine exception 2...");
        this.HelpLink = "http://exc2.com";
    }
}
3

There are 3 best solutions below

5
On

You are throwing an exception in the constructor of the ExceptOne exception. So an ExceptOne object will never be created and the catch for that exception will not be triggered.

EDIT

It can be OK to throw an exception in a constructor. See: http://bytes.com/topic/c-sharp/answers/518251-throwing-exception-constructor and When is it right for a constructor to throw an exception?

0
On

If you see that when you raise the ExceptOne exception in the constructor you throw a new Exception2 type of exception which is not caught in your Main(...) method and hence it gets caught in the general exception clause.

0
On

This happens because you throwing Exception2 in ExceptOne causing Exception2 to be caught in your main method by the (System.Exception r) block.

The base for ExceptOne is called, the message (set by base("base ctor 1 ")) is just never displayed because that exception is never caught.