Reputation: 4394
If I have two processes accessing a given registry key (e.g. HKLM
), should I wrap the the logic in a mutex?
Upvotes: 18
Views: 6437
Reputation: 54620
The registry will make sure the actions are atomic, so you don't have to synchronize it yourself.
However, if you have multiple processes / threads accessing the registry at the same time, it doesn't make any guarantees about which happens first. Only that you won't get garbled data.
Edit: Further reading, see The inability to lock someone out of the registry is a feature, not a bug.
Upvotes: 24
Reputation: 25866
Take a quick read of this Raymond Chen article. It explains that individual writes and reads against the registry are atomic. However, other locking is up to you as there's now way to hold a key open exclusively.
https://devblogs.microsoft.com/oldnewthing/20090326-00/?p=18703
Upvotes: 1
Reputation: 55435
As others have mentioned, individual operations are atomic. If you need to make a larger set of operations atomic, and you're targeting Vista or better, you can use the transactional registry support added in Vista.
Unfortunately, there is no direct managed support so you need to create wrappers.http://community.bartdesmet.net/blogs/bart/archive/2006/12/14/Windows-Vista-2D00-Introducing-TxR-in-C_2300_-_2800_Part-1_2900_.aspx shows how to P/Invoke these methods.
Upvotes: 5
Reputation: 45533
Windows Server 2008 also has support for transactional access to the registry. Here's the overview at MSDN. And here's a blog post announcing it with some questions and answers.
Upvotes: 2
Reputation: 27304
That depends on what you're communicating, and how time-critical the information is. Say, for example, that you have an app doing work and writing status results to a registry key, and another app reading that status and displaying it on-screen. In that case, I wouldn't bother with a mutex, as the reader will always get a value that "makes sense". What you're asking is really a fundamental question of concurrency design, I think.
Upvotes: 0