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

Reply via email to