Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Java: Meaning of catch (final SomeException e)?

What does final do in the following Java expression?

catch (final SomeExceptionType e) 
like image 775
Debajit Avatar asked Aug 18 '10 21:08

Debajit


People also ask

What is the meaning of catch in Java?

The catch statement allows you to define a block of code to be executed, if an error occurs in the try block.

What is E in a Catch statement?

'e' is just a variable. ('e' stands for exception, but you can rename it anything you like, however, the data type has to remain 'Exception') The 'e' variable stores an exception-type object in this case.

What is try catch and final in Java?

Try block contains the code that might throw an exception. Catch block contains the exception handler for exceptions in the try block. The finally block contains the critical code that will execute regardless of whether the exception has occurred or not.

What is final exception in Java?

The finally keyword is used to execute code (used with exceptions - try.. catch statements) no matter if there is an exception or not.


1 Answers

It basically means:

Catch "SomeExceptionType" into the variable "e" with the promise that we won't assign a different exception to "e" during the processing of the exception.

Mostly this is overkill, as if I'm catching an exception into a temporary variable name (e only is valid for the exception handling block), I don't have to police myself so strictly as to not trust myself to assign a different (possibly created) exception to the same variable name.

That said, perhaps this block is heavily maintained by a team of different-minded individuals, and one just wanted to be VERY sure that e was the original captured exception.

---- Edited in response to commentary ----

I can't think of a really excellent reason to do this. Since "e" is not a member (static or otherwise) the name "e" won't be used by the class file post-compilation. Another way of stating this is that when you enter the exception handling block of JVM bytecode, the object won't be assigned to any of the member names accessible by the JVM processing frame, it will be pushed to the internal processing stack of the Thread's current frame.

Even if two threads had access to the same Object, each thread would have it's own frame, so the compiler removed "e" name from one frame's internal stack couldn't be altered by the other thread.

With that in mind, the only benefit of declaring "e" final is to make sure that future coders don't accidentally set "e" after entering the block. Perhaps they meant to make the code more robust in a multi-threaded environment, but temporary variables (those with names that only are valid in the block) don't have names post-compilation, they are pushed onto the frame's stack.

That's why

public int safe() {   int x = 5;   x = x + 5;   return x; } 

is generally regarded as thread safe, because it does this (in pseudo bytecode)

(In the thread's current frame) push 5 push 5 add integers return 

While this isn't thread safe

int x = 5;  public void unsafe() {   x = 5;   x = x + 5;   return x; } 

because it does this

(in the thread's current frame) push "this" push 5 set member x push "this" get member x push 5 add integer set member x get member x return 

The latter bytecode makes it apparent that interleaving two threads creates thread-to-thread communications using member x an an intermediary, while the first block of code cannot have any inter-thread communication because there's no intermediary.

like image 62
Edwin Buck Avatar answered Sep 30 '22 13:09

Edwin Buck