Hi!

Actually I'm not quite sure about this, but I think you can assume that
this always works. I think what gets actually passed to printf is a
pointer to the value returned by c_str() which in turn is stored in some
independent temporary memory location until printf is done. 
I use a lot of constructs like this and it always worked for me, (Intel
& GNU) however I might still be wrong. :)

Benjamin

On Wed, 2005-01-19 at 21:56 +0100, [EMAIL PROTECTED] wrote:
> Hi all,
> 
> I have a function similar to the following, which returns a string:
> 
>   std::string foo() {
>     return <whatever>;
>   }
> 
> ..then I want to use its c_str(), say like this (sorry for the silly 
> example):
> 
>   int main() {
>     printf("foo is %s",foo().c_str());
>   }
> 
> Of course, for printf() to work, the temporary object that is returned 
> by foo() should not be (automatically) destroyed too early, or the 
> pointer returned by c_str() would not be valid anymore.
> 
> So, my question is: *when* is that temporary string created and 
> destroyed? is it safe to assume that it exists until printf() 
> returns, and thus that I can use its c_str() this way?
> 
> I've always thought that the temporary would be destroyed *before* 
> calling printf() [ create a string, get the value for c_str(), 
> destroy the string, invoke printf() ] thus actually passing an 
> invalid pointer in this case, but to my surprise I put together some 
> lines and gcc proved me wrong. Is it just gcc? Or is it a standard 
> C++ behavior?
> 
> Thanks,
> Andrea.
> -
> To unsubscribe from this list: send the line "unsubscribe 
> linux-c-programming" in
> the body of a message to [EMAIL PROTECTED]
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
-- 
Benjamin Sobotta <[EMAIL PROTECTED]>

-
To unsubscribe from this list: send the line "unsubscribe linux-c-programming" 
in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to