简体   繁体   中英

C++ function returning string

#include <iostream>

using namespace std;

string test(string s)
{
    string rv = "Hey Hello";
    if(s=="")
        return rv;
    else
        cout<<"Not returning"<<endl;

}

int main()
{
    string ss = test("test");
    cout<<ss<<endl;
}

The above code should not return any value and probably print garbage, but its returning " Hey Hello " even without return statement at the end in test function. Can you tell my why its behaving like this?

reaching the end of a function returning non-void without any return statement is undefined behavior

you should have compiler warning for this kind of things if they are active

compiler are allowed to assume that undefined behavior is unreachable so the compiler have probably deleted the if statement and kept only the branch that doesn't lead to undefined behavior

Sincerely I'm surprised that this code is compiling! You should consider the warnings as errors. Warnings are important.

My guess is that the compiler writer thought:

whenever the coder has a branch without return statement it probably means that she knows that the branch cannot be visited (for instance a precondition on the arguments is checked before calling the function) so the branch can be removed.

This could explain why the compiler behaves in this way. But a more formal answer to your question is: "this is undefined behavior, everything could happen".

When trying to compile it with gcc the output depends on the optimization level.

First of all, your test function causes undefined behavior because it doesn't return so literally anything can happen.

However if I were to speculate a little bit, the code behaves like this probably because it accidentally interprets the block of memory that used to be occupied by the rv local variable as the returned value. And that object happens to hold "Hello World". So although the function didn't properly return, the memory on the stack and heap could be interpreted as if the local variable was the result.

Nonetheless, that is only a guess and according to C++ standard it's just undefined behavior which means either you know what you're doing and you never let that not-returning path execute or the code is just wrong.

As Tyker mentioned, this code causes undefined behaviour, meaning everything can happen.

It is most likely caused by optimizer, which assumes that each execution branch returns some value, and based on this optimizes final code. You should try with optimization turned off, but note that every compiler can generate completely different results.

Take a look at disassembly (clang 4.0, -O3) of this function (I used char* instead of std::string):

test: # @test
  mov eax, .L.str.1
  cmp rdi, rax
  je .LBB0_2 // <<-- IF .L.str.1 == "", goto .LBB0_2
  // CALL PRINTF
  push rax
  mov edi, .L.str.2
  xor eax, eax
  call printf
  add rsp, 8
  // END OF CALL PRINTF
  .LBB0_2:
  mov eax, .L.str // <<--- RETURN .L.str to the caller (optimization!)
  ret

.L.str:
  .asciz "Hey Hello"

.L.str.1:
  .zero 1

Label .LBB0_2 is reached regardless of if statement results, so it's returned in every case.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM