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

  • @[email protected]
    link
    fedilink
    81 year ago

    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]
      link
      fedilink
      11 year ago

      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.

        • @[email protected]
          link
          fedilink
          11 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]
      link
      fedilink
      61 year ago

      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.

      • @[email protected]
        link
        fedilink
        2
        edit-2
        1 year ago

        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]
      link
      fedilink
      21 year ago

      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]
        link
        fedilink
        11 year ago

        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

        • @[email protected]
          link
          fedilink
          11 year ago

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

          • @[email protected]
            link
            fedilink
            English
            2
            edit-2
            1 year ago

            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.

    • @[email protected]
      link
      fedilink
      11 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.

  • @CrashTestDummy
    link
    11 year ago

    As ugly and stupid this feels, everyone here at one point or another is guilty of this. Some “temporary” code to place a breakpoint on cause you gave up trying to understand why the five thousand line function called compareVersion keeps throwing an exception trying to compare 1.0 to 2.0.

    • @[email protected]
      link
      fedilink
      91 year ago

      Why wouldn’t it? It’s syntactically valid C#, with the added bonus of destroying the stack trace

      • @Keelhaul
        link
        11 year ago

        Who needs stack traces anyway? Just search all of your code on the word throw until you have the right one