Re: Guaranteed copy elision

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Nov 19, 2022 at 6:12 PM Jonathan Wakely <jwakely.gcc@xxxxxxxxx>
wrote:

>
>
> On Tue, 15 Nov 2022, 05:48 Yubin Ruan via Gcc-help, <gcc-help@xxxxxxxxxxx>
> wrote:
>
>> Hi,
>>
>> As mentioned in cppreference:
>> https://en.cppreference.com/w/cpp/language/copy_elision
>>
>> it is guaranteed in c++17 that copy elision must be applied for some cases
>> like
>>
>>     SomeBigObject SomeBigObject::Factory(...) {
>>         SomeBigObject local;
>>          ...
>>          return local;
>>     }
>>
>
> No, this is not guaranteed. As the cppreference page explains, it's only
> guaranteed for copying temporaries. This is not a temporary.
>
> Elision here is allowed, but not required. It's commonly implemented
> though.
>
>
>
>
>> (examples taken from https://abseil.io/tips/11 )
>>
>> but not for cases like
>>
>>     SomeBigObject SomeBigObject::Factory(...) {
>>         SomeBigObject local1;
>>         SomeBigObject local2;
>>          ...
>>
>>          if (cond_1) {
>>              return local1;
>>          } else {
>>              return local2;
>>          }
>>     }
>>
>> For a c++ user, it is somewhat difficult to be 100% sure that copy elision
>> / NVO is applied to the functions' return value above.
>>
>> To be sure that a object would not be copied, we usually write something
>> like
>>
>>          SomeBigObject obj;
>>          func(&obj);
>>
>> while in most of the cases a one-liner like
>>
>>          SomeBigObject obj = func();
>>
>> would suffice.
>>
>> Is there any language facility to help us guarantee that at compile time
>> (such as some kind of static_assert() ) so that we can be confident
>> writing
>> those one-liner ?
>>
>
> Make it cheap to move, and then it will be moved instead of copied. The
> move isn't always elided, but if it's cheap then the code will still be
> efficient.
>

Thank you all.

It seems that currently the only way to guarantee  efficiency is to use
move instead.

--
Yubin



[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux