this post was submitted on 17 Jun 2023
144 points (96.8% liked)

Programmer Humor

32595 readers
1789 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
 

Brilliant exception handling I found in an app i had to work on

top 28 comments
sorted by: hot top controversial new old
[–] [email protected] 17 points 1 year ago (1 children)

Actually, exception rethrowing is a real thing - at least in Java. You may not always want to handle the exception at the absolute lowest level, so sometimes you will instead "bubble" the exception up the callstack. This in turn can help with centralizing exception handling, separation of concerns, and making your application more modular.

It seems counter-intuitive but it's actually legit, again at least in Java. lol

[–] [email protected] 5 points 1 year ago (1 children)

Rethrowing caught exception in C# is just throw;, not throw ex;. This will delete old stack trace, which is very punishable if someone debugs your code later and you're still around.

[–] bartimeo 1 points 1 year ago (2 children)

I am a somewhat new C# developer (2 years). Could you explain more about this?

[–] CatPoop 1 points 1 year ago* (last edited 1 year ago)

An exception will bubble up the stack until it enters a catch block that can handle it, and you may need additional logic to decide if you are finished, or it needs to go further up. (you may also intercept it just to add more data, or log it)

throw; allows you send the original exception further up, but throw ex; behaves the same as throwing a new Exception object, and therefore has a new trace. The throw statement doesn’t query any properties on the exception argument AFAIK, so it has no idea this exception has been previously thrown, but the IDE is smart enough to know you almost certainly don’t want to do this.

[–] [email protected] 1 points 1 year ago

throw ex; treats ex as a new exception, so, it starts a new stack trace for it from itself and deletes stack trace that was saved in ex.StackTrace. On the other hand, throw; takes already present exception in the scope and throws it without modifying the stack trace, preserving the original method that threw ex in the stack trace.

I feel like I wrote the same thing twice. I'm a bit bad with explaining stuff, feel free to ask more specific questions if you still don't understand the difference.

[–] [email protected] 15 points 1 year ago* (last edited 1 year ago)

Seen this so many times, i weep for humanity

[–] [email protected] 14 points 1 year ago

I'm offended that you'd put my code on the internet.

[–] [email protected] 7 points 1 year ago

“I’ll come back to this”

[–] Shareiff 6 points 1 year ago (6 children)

Lol what’s wrong with this if the parent function catches it

[–] [email protected] 13 points 1 year ago (1 children)

If this is C# (and it looks like it is), this leads to you losing the original stack trace up until this point.

The correct way to do this in C# is to just throw; after you're done with whatever you wanted to do in the catch.

[–] jyte 4 points 1 year ago* (last edited 1 year ago) (1 children)

wait what ?

So you are saying that the following code will keep throwing e but if I used throw e; it would basically be the same except for the stack trace that would be missing the important root cause ?!

try {
} catch (WhateverException e) {
    // stuff, or nothing, or whatever
    throw; 
}
[–] [email protected] 4 points 1 year ago

Exactly. Aside from deleting your already built stack trace, as a bonus you'll get another stack trace building call, enjoy wasted CPU cycles.

[–] chillhelm 6 points 1 year ago (1 children)

Depending on the language it either does nothing and just adds code bloat or (and this would be much worse) it will catch any exception that can be implicitly cast to type Exception and throw it as type Exception. So the next higher scope would not be able to catch e.g. a RuntimeException or w.e. to handle appropriately. It could only catch a regular Exception even if the original error was a more detailed type.

[–] [email protected] 5 points 1 year ago (1 children)

It's C# so it's just rethrowing the original exception.

It might also be messing with the stack trace though which can be a bit frustrating for future debugging. But that's only a vague recollection of something I read in the past so I could be wrong

[–] Pieisawesome 1 points 1 year ago (1 children)

Throwing exceptions are very costly due to the stack trace, so building the stack trace twice will cause a big performance hit

[–] [email protected] 2 points 1 year ago* (last edited 1 year ago) (1 children)

Correct me if I'm wrong, but this will actually cut the stack trace and then start another one from your try-catch block, which is an evil thing to do towards those who will actually read your stack traces. To preserve the stack trace you do throw;, not throw ex;, and I'm assuming IDE is underlining that statement exactly for this reason.

[–] Pieisawesome 1 points 1 year ago

Yes, hence why I mentioned it collects the stack trace twice.

It's more than just more difficult for debugging

[–] [email protected] 3 points 1 year ago (1 children)

The catch is useless if it's just throwing the exception anyway

[–] [email protected] 2 points 1 year ago

The catch is mandatory...

[–] [email protected] 3 points 1 year ago

You don't catch it if that's the case

[–] [email protected] 2 points 1 year ago

You could just not catch it and it'll get thrown up the stack anyway.

[–] [email protected] 1 points 1 year ago

Then the parent function would catch the original exception if it was never caught in the first place. All this does is bork the stacktrace.

[–] [email protected] 3 points 1 year ago
while (true) {
    start();
}
load more comments
view more: next ›