Great g++ bug! Local destructor isn't called!
Assinovsky, Lev
LAssinovsky@algorithm.aelita.com
Wed Mar 10 15:59:00 GMT 2004
Five conditions must be true to get that bug:
1. Method throwing exception must have an exception specifier.
2-4. Method calling the method above must be VIRTUAL, must not have an exception specifier and
must be called through base class pointer or reference.
5. Compile with option -On, n > 0.
----
Lev Assinovsky
Aelita Software Corporation
O&S InTrust Framework Division, Team Leader
ICQ# 165072909
> -----Original Message-----
> From: Tony Wetmore [mailto:tony.wetmore@solipsys.com]
> Sent: Wednesday, March 10, 2004 6:23 PM
> To: 'Eljay Love-Jensen'; Assinovsky, Lev; gcc-help@gcc.gnu.org
> Subject: RE: Great g++ bug! Local destructor isn't called!
>
>
> Interestingly, ~Object() is also called if you ADD a "throw(int)"
> specifier to the FromBase::Run() method that invokes the Raiser
> constructor. Tested on Linux with GCC 3.3.1.
>
> ---
> Tony Wetmore
> Raytheon Solipsys
> mailto:tony.wetmore@solipsys.com
> http://www.solipsys.com
>
>
>
>
> -----Original Message-----
> From: gcc-help-owner@gcc.gnu.org
> [mailto:gcc-help-owner@gcc.gnu.org] On
> Behalf Of Eljay Love-Jensen
> Sent: Wednesday, March 10, 2004 9:46 AM
> To: Assinovsky, Lev; gcc-help@gcc.gnu.org
> Subject: Re: Great g++ bug! Local destructor isn't called!
>
>
> Hi Lev,
>
> I notice that if the throw(int) specification is taken off the Raiser
> constructor, then the ~Object() is called with -O3.
>
> (I'm using GCC 3.3.1 on CygWin / Windows XP.)
>
> Very odd. Good catch. Have you filed a bug?
>
> BTW, in general, I've found that it's usually best NOT to put
> in throw
> specifications for functions / methods. Ever. (This restriction does
> not
> apply to putting in the "throw() -- I throw nothing, ever"
> specification. But even that should be used with great caution.)
>
> If C++ did exception specifications like how Java does them,
> then that'd
> be
> a different story.
>
> --Eljay
>
>
>
More information about the Gcc-help
mailing list