9

This is probably a fairly easy question to answer, but it has been bugging me some time.

If there is a return statement inside an if statement, inside a method (in the Java language), but I add another at the end as a catch-all and to avoid the error, are both return values going to be fired one after the other if the if statement is true?

An example:

public int getNumber() {
 if( 5 > number) {
 return 5;
 }
 return 0;
 }

Result: Method returns 5, and then via stacks logic, returns 0 shortly thereafter.

Or, do I need to use an outside variable like so:

int num = 1;
public int getNumber() {
 if( 5 > number) {
 num = 5;
 }
 return num;
 }

Result: Method changes variable num to 5, then num is returned for use. I suppose in this case, the return statement wouldn't necessarily be required depending on the variable's usage.

Thanks in advance.

A13X
  • 409
  • 1
  • 6
  • 27

2 Answers2

12

No, both values aren't going to be returned. A return statement stops the execution of the method right there, and returns its value. In fact, if there is code after a return that the compiler knows it won't reach because of the return, it will complain.

You don't need to use a variable outside the if to return it at the end. However, if your method is long and complex, this technique can help readability and clarity because only one return statement is used.

rgettman
  • 176,041
  • 30
  • 275
  • 357
1

Only the first return statement hit is used. The method then terminates.

There are some code conventions that frown on multiple return statements because they might be hard to read, but I'm not one of them. :)

Xabster
  • 3,710
  • 15
  • 21
  • That's alright, I guess I'll break convention for now. Thanks for the answer. – A13X Aug 16 '13 at 22:18
  • @A13X - It's a pretty atypical convention. See [Should a function have only one return statement?](http://stackoverflow.com/questions/36707/should-a-function-have-only-one-return-statement) – femtoRgon Aug 16 '13 at 22:25