Do you prefer checked exception handling like in Java or unchecked exception handling like in C# and why?
Do you prefer checked exception handling like in Java or unchecked exception handling like
Share
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
Meh.
Checked exceptions are a great thing when used properly, but more often than not they lead to stuff like:
And, frankly, that’s just wrong. You should let exceptions you don’t handle bubble up.
Checked exceptions used properly can be good. But very frequently, the result of doing checked exceptions properly is method signatures like this:
Am I exaggerating? Only slightly.
Edit:
That said, one thing I prefer about C# over Java when it comes to exception handling has nothing to do with checked exceptions (I can get that if I go with Spec# anyway). No, what I like is that the stack trace in C# is populated when you throw an exception, rather than when you instantiate one as it is in Java.
Edit 2: This is for the commenters @Yishai, @Eddie, @Bill K:
First, you should check out this thread for information on how to get a stack trace without instantiating an exception. Keep in mind that walking the stack is a heavy process and should not be done on a regular basis.
Second, the reason I like C#’s exception stack trace being populated at throwal rather than at instantiation is that you can do things like this:
That’s a trick you can’t do in Java without having the
NewExceptionmethod included in the stack trace.