Не так per se , потому что функция должна изменить переменную a
, чтобы она была эквивалентной. Тем не менее, после встраивания и небольшой тривиальной оптимизации результат будет таким же:
int x = func(5);
// pseudo-inlined:
int __temp = 5; // the temporary created by binding 5 to int&&
__temp = 3; // a = 3;
int x = __temp; // return a;
// constant propagation:
int __temp = 5;
__temp = 3;
int x = 3;
// dead-code elimination:
int x = 3;
Обратите внимание, что результат такой же, как если бы вы использовали второе определение func
и встроенный, только потому, что временная переменная не использовалась. Это показывает, что две функции в целом не эквивалентны:
int modifyme = 100;
int x = func(std::move(modifyme));
// modifyme must be 3, second function definition wouldn't do that