[cfe-commits] r118158 - in /cfe/trunk: include/clang/Analysis/CFG.h lib/Analysis/CFG.cpp test/Analysis/temp-obj-dtors-cfg-output.cpp

Marcin Świderski marcin.sfider at gmail.com
Wed Nov 3 07:08:45 PDT 2010


W dniu 3 listopada 2010 12:15 użytkownik Zhongxing Xu <xuzhongxing at gmail.com
> napisał:

>
>
> 2010/11/3 Marcin Świderski <marcin.sfider at gmail.com>
>
>> 2010/11/3 Zhongxing Xu <xuzhongxing at gmail.com>
>>
>>
>>>
>>> On Wed, Nov 3, 2010 at 2:19 PM, Marcin Swiderski <
>>> marcin.sfider at gmail.com> wrote:
>>>
>>>> Author: sfider
>>>> Date: Wed Nov  3 01:19:35 2010
>>>> New Revision: 118158
>>>>
>>>> URL: http://llvm.org/viewvc/llvm-project?rev=118158&view=rev
>>>> Log:
>>>> Added generating destructors for temporary objects. Two cases I know of,
>>>> that are not handled properly:
>>>> 1. For statement: const C& c = C(0) ?: C(1) destructors generated for
>>>> condition will not differ from those generated for case without prolonged
>>>> lifetime of temporary,
>>>> 2. There will be no destructor for constant reference member bound to
>>>> temporary at the exit from constructor.
>>>>
>>>>
>>> Hi Marcin,
>>>
>>> Could you please provide two examples for these cases?
>>>
>>
>> Examples in attachment.
>>
>> In test_impl_cond() you can see that when assigning expression result to
>> regular variable both temporaries are destroyed and this is correct. But
>> when assiging to constant reference, temporary in condition should be
>> destroyed only when false branch is taken.
>>
>
> There are other problems in this example. There are two dtors in B6. One is
> due to an elidable CXXConstructExpr. Maybe we should not add
> CXXBindTemporaryExpr whose subexpr is an elidable CXXConstructExpr.
>

Elidable CXXConstructExpr should inhibit calling destructor for temporary
that is copied, not the one created. This is because eliding copy
constructor means that the object that was to be copied will be constructed
directly in memory the copy would be constructed in. Doing this as you
propose will work fine for eliding copy from temporary to temporary (balance
between ctors and dtors will be preserved), but won't work for eliding copy
from temporary to variable (there will be one more dtor called).

Balance between ctors and dtors is more important IMO, so I wouldn't do this
way.

>
>
>>
>> In TestConstRefMember constructor temporary is created and should be
>> destroyed at the exit from constructor (after "int b").
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20101103/7ddc6fa1/attachment.html>


More information about the cfe-commits mailing list