Talk About Network

Google


Register and Login
Nick
Password
Register create new account Sign up is FREE and you can post replies, new topics, bookmark posts and more!
Recover lost password


Programming > Programming Threads > Re: POD functio...
Latest [ Topics | Posts ] Archive Post A New Topic Post a Reply
<< Topic < Post Post 7 of 19 Topic 4068 of 4146
Post > Topic >>

Re: POD function static initialization from function return, thread

by Thomas Richter <thor@[EMAIL PROTECTED] > Oct 7, 2008 at 04:57 AM

Anthony Williams wrote:
> Thomas Richter <thor@[EMAIL PROTECTED]
> writes:
> 
>> Brian Cole wrote:
>>> I know that static initialization is not considered threadsafe from
>>> previous posts on this list. However, if a function static is POD
>>> being initialized by a function call then the value should always be
>>> initialized correctly, even if a inconsequential race condition
>>> occurs. This assumes that POD assignments are atomic, what platforms
>>> is this not true on?
>> All I know of. For example,
>>
>> struct foo {
>> 	int a,b;
>> };
>>
>> static struct foo f = {1,2};
>>
>> is a POD initialization, and if two threads run into this line of
>> code, it may happen that thread A initializes f.b while thread B is
>> already using f.b for something else, so no, this is definitely not
>> safe. 
> 
> Wrong. Initialization of a POD struct with an aggregate initializer
> consisting only of constant expressions is static initialization and
> must happen before the execution of the program begins.


Is this guaranteed? I don't think it is, and I doubt you can depend on 
it. Specifically, f is non-const here, so the compiler should have IMHO 
the freedom of placing the initializer into the code/text section, and 
copy the data on demand during execution so code can modify it. This is 
what g++ does, and it would definitely be not safe wouldn't gcc wrap 
this test into a mutex. AFAIK, the only requirement that does exist is 
that f must be initialized before the first usage, and that might be 
after loading time.

Things *might* be better with const, they definitely are for g++, but 
once again, I cannot find this requirement in the C standard.

So long,
	Thomas
 




 19 Posts in Topic:
POD function static initialization from function return, thread
Brian Cole <coleb2@[EM  2008-10-03 15:07:52 
Re: POD function static initialization from function return, thr
Thomas Richter <thor@[  2008-10-04 11:02:01 
Re: POD function static initialization from function return, thr
"Chris M. Thomasson&  2008-10-04 04:51:49 
Re: POD function static initialization from function return, thr
Thomas Richter <thor@[  2008-10-04 15:15:57 
Re: POD function static initialization from function return, thr
"Chris M. Thomasson&  2008-10-04 18:34:18 
Re: POD function static initialization from function return, thr
Anthony Williams <anth  2008-10-06 14:13:37 
Re: POD function static initialization from function return, thr
Thomas Richter <thor@[  2008-10-07 04:57:53 
Re: POD function static initialization from function return, thr
Anthony Williams <anth  2008-10-07 08:05:35 
Re: POD function static initialization from function return, thr
Thomas Richter <thor@[  2008-10-08 01:16:48 
Re: POD function static initialization from function return, thr
Hallvard B Furuseth <h  2008-10-06 19:42:02 
Re: POD function static initialization from function return, thr
David Schwartz <davids  2008-10-07 11:11:24 
Re: POD function static initialization from function return, thr
Thomas Richter <thor@[  2008-10-08 01:20:28 
Re: POD function static initialization from function return, thr
Anthony Williams <anth  2008-10-08 08:18:27 
Re: POD function static initialization from function return, thr
Brian Cole <coleb2@[EM  2008-10-07 11:31:54 
Re: POD function static initialization from function return, thr
Anthony Williams <anth  2008-10-08 08:13:53 
Re: POD function static initialization from function return, thr
David Schwartz <davids  2008-10-08 19:47:13 
Re: POD function static initialization from function return, thr
Thomas Richter <thor@[  2008-10-11 01:44:35 
Re: POD function static initialization from function return, thr
David Schwartz <davids  2008-10-08 19:50:33 
Re: POD function static initialization from function return, thr
David Schwartz <davids  2008-10-10 21:24:11 

Post A Reply:
  Go here to Signup

AddThis Feed Button


About - Advertising - Contact - Frequently Asked Questions - Privacy Policy - Terms of Use - Signup

Contact
tan12V112 Sat Nov 22 8:51:52 CST 2008.