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 6 of 19 Topic 4068 of 4146
Post > Topic >>

Re: POD function static initialization from function return, thread safe?

by Anthony Williams <anthony.ajw@[EMAIL PROTECTED] > Oct 6, 2008 at 02:13 PM

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.

> Even if you return a copy of f from a function:
>
> struct foo init_me(void)
> {
> static struct foo f = {1,2};
>
> return f;
> }

This too is safe.

> void bar(void)
> {
> static struct foo = bla();
> }
>
> might call bla() once or several times, and might leave a second
> thread with a partially initialized "foo" because a first thread
> already set the "is initialized" flag on entry before the value has
> been copied over completely.
>
> In short: Don't do that.

Totally agree here. Dynamic initialization is not safe.

>> For example:
>>
>> unsigned int Bar(); // assumed to be a thread safe function that
>> returns the same value every time
>> void Foo()
>> {
>>   static unsigned int value = Bar();
>> }
>
> Here you are returning an "int", not only a POD. On some
> architectures, "int"s can be accessed "atomically", probably under
> certain constraints (i.e. alignment), but once again, this is not a
> construction that you should depend on.

Agree that this is still not safe: it's still dynamic initialization.

Anthony
-- 
Anthony Williams            | Just Software Solutions Ltd
Custom Software Development | http://www.justsoftwaresolutions.co.uk
Registered in England, Company Number 5478976.
Registered Office: 15 Carrallack Mews, St Just, Cornwall, TR19 7UL
 




 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 9:49:59 CST 2008.