views:

126

answers:

3

I have a thread that sets a value to true when it is done. Until then I wait:

while(1)
{
    if(done[0] == true)
    {

        break;
    }
}

This code works just fine in Debug but in Release it stays in the loop forever even though the debugger clearly says that it is true and not false.

Why would this not work?

Thanks

+14  A: 

This is symptomatic of not marking done as volatile.

Without volatile the optimising compiler can cache the value in a register.

e.g.

private volatile int i;
Mitch Wheat
Yup that did the trick! Thanks
Milo
+5  A: 

On a side note, It's NOT (IMHO) a good practice to do something like that. You have probably (smartly) simplify your problem, but create a busy loop like that to wait on some task to finish is a bad, bug prone method. You should probably use some locking/event mechanism (or at the very least add sleep to the loop).

Guy
+1  A: 

This generally is a bad design idea.

Since you are using VS I guess you are targeting windows so I suggest you take a look at WaitForSingleObjects or WaitForMultipleObjects depending on your criteria.

Or if you are just updating stuff on screen maybe take a look at WM_KICKIDLE.

graham.reeds
Agreed. The compiler has done you a huge favour by failing here!
Sharkey