When an unhandled exception happens while debugging some code in any procedure/function/method, the debugger stops there and shows the message.
If I now continue debugging step by step, the execution jumps directly from the line that created the exception to the end of the current procedure (if there is no finally block).
Woulnd’t it be just as good to continue with the next line of the current procedure?
Why jump to the end of the proc and continue with the calling procedure? Is this just by design or is there a good reason for it?
In general, an uncaught exception will execute a hidden ‘finally’ in each function on the stack, as it ‘unwinds’ up to an exception handler. This cleans up local variables in each stackframe. In languages like C++ with the Resource Acquisition Is Initialization paradigm, it will also cause destructors to run.
Eventually, somewhere up the callstack, the exception will be caught by a handler. If there’s no explicit one, the system-provided one will kill the process, because what else can it reasonably do?