当然通常情况下我们还可以用另外一种方法来解决这类问题,那便是设置互斥量。一般情况下我们可以使用互斥量,临界区等来实现。在这里我使用了互斥量,主要是因为我需要在多个不同的进程中并发的访问同一个数据库。用于锁定和解锁的函数如下:
void Lock()
{
if((hCounter = OpenMutex(MUTEX_ALL_ACCESS,FALSE,"kangxiaofang")) == NULL)
{
//如果没有其他进程创建这个互斥量,则重新创建
hCounter = CreateMutex(NULL,FALSE,"kangxiaofang");
WaitForSingleObject(hCounter,INFINITE); //---->这里就光只是等待,可是等待完了呢?什么也没干也可以吗? By Ouyongke
}
else
{
WaitForSingleObject(hCounter,INFINITE); //---->这里也是 By Ouyongke
}
}
void UnLock()
{
//释放使用权
ReleaseMutex(hCounter);
//关闭句柄
CloseHandle(hCounter);
}
当然我们也可以把等待时间设定为60秒,以免出现死等的现象。具体使用时可以按如下调用:
//锁定数据库
Lock();
rc = sqlite3_exec(db, "BEGIN;", 0, 0, &zErrMsg);
rc = sqlite3_exec(db, exec, 0, 0, &zErrMsg);
rc = sqlite3_exec(db, "COMMIT;", 0, 0, &zErrMsg);
//数据库解锁
UnLock();
总结:
经过测试后,你会发现这种方法所需的消耗要小于循环打开数据库的操作。