以下是使用 CCriticalSection::Unlock 的简单示例:
#include <afxmt.h>
// ...
CCriticalSection g_criticalSection; // 全局临界区对象
// ...
// 在某个函数或代码块中使用临界区
void SomeFunction()
{
// ...
g_criticalSection.Lock(); // 进入临界区
// 在这里执行需要同步的操作
g_criticalSection.Unlock(); // 离开临界区
// ...
}
在这个例子中,g_criticalSection.Unlock() 被用于离开先前通过 Lock 进入的临界区。在执行完需要同步的操作后,通过调用 Unlock,线程释放对临界区的控制,允许其他线程再次进入。
为了确保在任何情况下都能正确释放临界区,最好使用 RAII(Resource Acquisition Is Initialization)原则。可以使用 CAutoLock 对象:
#include <afxmt.h>
// ...
CCriticalSection g_criticalSection; // 全局临界区对象
// ...
// 在某个函数或代码块中使用临界区
void SomeFunction()
{
// ...
CAutoLock lock(&g_criticalSection); // 进入临界区,离开临界区时会自动调用 Unlock
// 在这里执行需要同步的操作
// 不需要显式调用 Unlock
// ...
}
CAutoLock 的构造函数会在创建时自动调用 Lock 进入临界区,而在对象离开作用域时,会自动调用 Unlock 离开临界区,这样可以更安全地管理临界区的使用。
转载请注明出处:http://www.zyzy.cn/article/detail/16099/MFC/CCriticalSection