Can I use a return statement in a function returning void?
Asked Answered
D

9

59

I have to return to the previous level of the recursion. is the syntax like below right?

void f()
{
   // some code here
   //
   return;
}
Dilantin answered 12/2, 2010 at 1:39 Comment(3)
have you tried compiling?Brigittebriley
@Mitch: Reasonable as that is, it only proves that your compiler supports it, not whether it is actually valid C++. E.g. I can easily "prove" that void main() is correct that way.Mv
It is, but it's hard to see the point of a recursive void method, unless it has reference out parameters.Crabstick
T
119

Yes, you can return from a void function.

Interestingly, you can also return void from a void function. For example:

void foo()
{
  return void();
}

As expected, this is the same as a plain return;. It may seem esoteric, but the reason is for template consistency:

template<class T>
T default_value()
{
  return T();
}

Here, default_value returns a default-constructed object of type T, and because of the ability to return void, it works even when T = void.

Tyrannicide answered 12/2, 2010 at 2:21 Comment(4)
is it the same thing if in the return instruction, you call a function, which returns a void ? e.g. return f(); where the prototype of f is void f();Adna
oh wait, so this constructor has void( void ) signature? So return void( void() ) is valid also. Code obfuscation contest anyone?Merl
Does this also apply if e.g. I have a void foo(); and, in void bar(), I return foo()?Selfrealization
oh that's weird. Why does T() need to work for T = void when we never need to instantiate the function template?Clavicembalo
C
15

Sure. You just shouldn't be returning an actual value.

Climber answered 12/2, 2010 at 1:41 Comment(0)
B
10

Yes, you can use that code to return from the function.

Bituminous answered 12/2, 2010 at 1:41 Comment(0)
T
4

Yes, sometimes you may wish to return void() instead of just nothing.

Consider a void function that wants to call some pass-through void functions without a bunch of if-else.

return 
  InputEvent == E_Pressed ? Controller->Grip() :
  InputEvent == E_Released ? Controller->Release() :
  InputEvent == E_Touched ? Controller->Touch() : void();
Trichinosis answered 13/7, 2018 at 4:59 Comment(0)
B
3

Yes, that will return from the function to the previous level of recursion. This is going to be very basic explanation, but when you call a function you are creating a new call stack. In a recursive function you are simply adding to that call stack. By returning from a function, whether you return a value or not, you are moving the stack pointer back to the previous function on the stack. It's sort of like a stack of plates. You keep putting plates on it, but than returning moves the top plate.

You could also verify this by using a debugger. Just put a few break points in your code and step through it. You can verify yourself that it works.

Buxom answered 12/2, 2010 at 1:44 Comment(1)
Stack frame. New threads get new stacks, function calls get new stack frames on the same stack in a given thread. Just want to clear up that detail because it might confuse newcomers.Whittaker
K
3

The simple answer to this is YES! C++ recognise void method as a function with no return. It basically tells the compiler that whatever happens, once you see the return; break and leave the method....

Katalin answered 12/2, 2010 at 1:47 Comment(0)
S
2

You shouldn't have to have the return there, the program will return to the previous function by itself, go into debug mode and step through and you can see it yourself. On the other hand i don't think having a return there will harm the program at all.

Subassembly answered 12/2, 2010 at 1:42 Comment(1)
Yes, you are correct. Although without knowing what the some code here reference is referring to it may make sense to be explicit. Although the return just before the closing brace is extraneous.Buxom
G
1

As everyone else said, yes you can. In this example, return is not necessary and questionably serves a purpose. I think what you are referring to is an early return in the middle of a function. You can do that too however it is bad programming practice because it leads to complicated control flow (not single-entry single-exit), along with statements like break. Instead, just skip over the remainder of the function using conditionals like if/else().

Grampus answered 12/2, 2010 at 5:7 Comment(0)
M
0

Yes, for example:

void foo()
{
    // do smth
}

and then

void bar(bool condition)
{
    if (condition) {
        return foo(); //its ok
    }
    // else do smth
}
Martyrdom answered 2/3, 2023 at 8:54 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.