NeuralJack Posted September 6, 2006 Posted September 6, 2006 I was thinking about how nice it would be to have a global try/catch that would catch errors not handled by the subroutines themselves. this would be sort of a last-resort safety net to stop your program from just crashing on the user if something odd happens. Currently most of my functions have a try/catch statement, but if there was a global version it would save lots of code Quote Currently Using: Visual Basic.Net 2005, .Net Framework 2.0
Cags Posted September 6, 2006 Posted September 6, 2006 Try/Catch are generally used in places where an error is reasonably likely, for example when communicating with something outside your own application (File IO, Network comms etc). Due to the way they are used you will generally have a good idea what the error will be and what your application should do about it. For example if a subroutine fails to open a file, you might tell the user then continue regardless. How would you apply such a system to a global Try/Catch? If the statement will catch everything you've failed to account for it's an unknown error, and theres not really alot of point in catching an unknown error. Say you did catch it, what would you then do with that error, the chances are if it's not an error you anticipated, your application won't function for long afterwards. Quote Anybody looking for a graduate programmer (Midlands, England)?
NeuralJack Posted September 6, 2006 Author Posted September 6, 2006 Ya, I know. The main reason for wanting such a general thing is to essentially give the user the ability to Close the program or Continue (knowing a major unknown error has occured). Also what you can do is catch the error type and other information (sub routine name, line number, etc) and have a form where that error information can be sent via email, or something to the programmer. I realize any responsible programmer is going to try hard to cover all bases for catching errors.. but was just wondering if there could be a super safety net. Try/Catch are generally used in places where an error is reasonably likely' date=' for example when communicating with something outside your own application (File IO, Network comms etc). Due to the way they are used you will generally have a good idea what the error will be and what your application should do about it. For example if a subroutine fails to open a file, you might tell the user then continue regardless. How would you apply such a system to a global Try/Catch? If the statement will catch everything you've failed to account for it's an unknown error, and theres not really alot of point in catching an unknown error. Say you did catch it, what would you then do with that error, the chances are if it's not an error you anticipated, your application won't function for long afterwards.[/quote'] Quote Currently Using: Visual Basic.Net 2005, .Net Framework 2.0
Administrators PlausiblyDamp Posted September 6, 2006 Administrators Posted September 6, 2006 The AppDomain.CurrentDomain.UnhandledException event is probably what you are after then. Quote Posting Guidelines FAQ Post Formatting Intellectuals solve problems; geniuses prevent them. -- Albert Einstein
NeuralJack Posted September 6, 2006 Author Posted September 6, 2006 Sweet, thanks PD The AppDomain.CurrentDomain.UnhandledException event is probably what you are after then. Quote Currently Using: Visual Basic.Net 2005, .Net Framework 2.0
ehelin Posted September 7, 2006 Posted September 7, 2006 Not sure if this helps...but we have an error class that we direct all of our error calls to as well as all close/end events (i.e. instead of system.environment.exit(0), we use LocalErrorLink.GoodExit(0)). By funneling everything through this class, you are guaranteed to have one exit point where all errors/exit calls are sent...which could give you the "global" spot to decide what to do if an error occurs. Quote
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.