每天学一点 — CCriticalSection临界区

每天学一点 — CCriticalSection临界区(转)类CCriticalSection的对象表示一个“临界区”,它是一个用于同步的对象,同一时刻只允许一个线程存取资源或代码区。临界区在控制一次只有一个线程修改数据或其它的控制资源时非常有用。例如,在链表中增加一个结点就只允许一次一个线程进行。通过使用CCriticalSection对象来控制链表,就可以达到这个目的。它就像是一把钥匙,哪个线程获得了它就获得了运行线程的权力,而把其他线程统统阻塞

大家好,又见面了,我是你们的朋友全栈君。

(转)类CCriticalSection的对象表示一个“临界区”,它是一个用于同步的对象,同一时刻只允许一个线程存取资源或代码区。临界区在控制一次只有一个线程修改数据或其它的控制资源时非常有用。例如,在链表中增加一个结点就只允许一次一个线程进行。通过使用CCriticalSection对象来控制链表,就可以达到这个目的。它就像是一把钥匙,哪个线程获得了它就获得了运行线程的权力,而把其他线程统统阻塞。

如此的话,每个线程共享一个CCriticalSection变量,只要CCriticalSection->lock和Unlock就能达到目的!

在一个函数内部,我们可以用一个局部变量的生存空间对应的构造和析构函数来自动调用CCriticalSection的功能,实在是妙极妙极!,如下代码:

–头文件–

//资源锁定
class COM_SERVICE_CLASS CThreadLock
{

//变量定义
private:
INT m_nLockCount; //锁定计数
CCriticalSection & m_CriticalSection; //锁定对象

//函数定义
public:
//构造函数
CThreadLock(CCriticalSection & CriticalSection, bool bLockAtOnce=true);
//析构函数
virtual ~CThreadLock();

//操作函数
public:
//锁定函数
VOID Lock();
//解锁函数 
VOID UnLock();

//状态函数
public:
//锁定次数
inline INT GetLockCount() { return m_nLockCount; }
};

–cpp文件–

//构造函数
CThreadLock::CThreadLock(CCriticalSection & CriticalSection, bool bLockAtOnce) 
: m_CriticalSection(CriticalSection)
{

//设置变量
m_nLockCount=0;

//锁定对象
if (bLockAtOnce==true)
{

Lock();
}

return;
}

//析构函数
CThreadLock::~CThreadLock()
{

//解除锁定
while (m_nLockCount>0)
{

UnLock();
}

return;
}

//锁定函数
VOID CThreadLock::Lock()
{

//锁定对象
m_nLockCount++;
m_CriticalSection.Lock();

return;
}

//解锁函数
VOID CThreadLock::UnLock()
{

//效验状态
ASSERT(m_nLockCount>0);
if (m_nLockCount==0) return;

//解除锁定
m_nLockCount–;
m_CriticalSection.Unlock();

return;
}


如果哪里要用到临界区,CThreadLock lock(m_CriticalSection);直接调用就可以了 ~~ 妙

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/162035.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • MySQL数据库:drop、truncate、delete的区别

    MySQL数据库:drop、truncate、delete的区别

  • Tortoise小乌龟SVN回滚到之前的提交版本,即如何撤销此次提交操作

    Tortoise小乌龟SVN回滚到之前的提交版本,即如何撤销此次提交操作

  • Object-c @property的用法

    Object-c @property的用法

  • mysql 如何修改用户密码_如何更改MySQL用户密码

    mysql 如何修改用户密码_如何更改MySQL用户密码在本教程中,我们将向您展示如何更改MySQL用户密码。这些说明应适用于任何现代Linux发行版,例如Ubuntu18.04和CentOS7。先决条件根据系统上运行的MySQL或MariaDB服务器版本,您将需要使用不同的命令来更改用户密码。您可以通过发出以下命令来找到数据库服务器版本:mysql–version如果您的系统中安装了MySQL,则输出将类似于以下内容:mysqlVer14…

  • 3.1 代价函数[通俗易懂]

    3.1 代价函数[通俗易懂]3.1代价函数(costfunction)    代价函数有助于将最可能的线性函数与我们的数据相拟合。在线性回归中,我们有一个这样的数据集,m表示训练集样本数,而我们的假设函数,也就是我们用来进行预测的函数,是图中所示的线性函数形式。    接下来,我们引入一些术语,Ɵ0和Ɵ1,这些Ɵi我们将它称作为模型参数,我们要做的就是如何去选择这两个参数。对于不同的Ɵ0和Ɵ1,我们会得到不同

  • PLSQLDeveloper14连接Oracle11g

    PLSQLDeveloper14连接Oracle11g提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录一、环境配置1.安装PLSQLDeveloper142.下载并解压Oracle客户端3.配置window操作系统环境变量二、工具配置1.Oracle客户端配置2.PLSQLDeveloper14配置3.重启PLSQLDeveloper14客户端结尾一、环境配置1.安装PLSQLDeveloper14官网自行下载,不详细阐述2.下载并解压Oracle客户端例如版本:instantclient-basic-nt-19.8.0

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号