On 06/23/2011 12:37 AM, Malcom Haak wrote:
Correct me if I'm wrong, But can't you technically make any code
'thread-safe' by using Critical Sections before doing work.
Of course you are correct. But this is not a decent way to go.
1) the calls of CriticalSection themselves can slow down the code, as
they need library and (unless the Library and the Arch decently
implements FUTEX) System API calls. And even with FUTEX, hardware-locked
instructions need to be use that might count for hundreds of normal
instructions with modern processors due to necessary cache syncing.
2) if the CriticalSection in fact requires waiting the increase in
latency is huge. So the calls should be placed only there where they are
really necessary and the code should be optimized to run as little
within CriticalSections as possible.
In some code I have seen before a critical section was entered before
calling TList.Add
Now provided that you don't need a specific order, does this not then
make it thread safe?
Yes, but in General it's not a decent way to go.
That is why I state that TList (supposedly) already is "per-instance
thread safe" and does not need further ado if no concurrent thread
accesses the same instance.
-Michael
--
_______________________________________________
Lazarus mailing list
[email protected]
http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus