[发明专利]一种资源访问时自旋锁的实现方法、装置及设备在审
申请号: | 202010697107.1 | 申请日: | 2020-07-20 |
公开(公告)号: | CN111984428A | 公开(公告)日: | 2020-11-24 |
发明(设计)人: | 朱鸿斌;宫耀东;夏之春;左若愚;刘艳云 | 申请(专利权)人: | 上海金仕达软件科技有限公司 |
主分类号: | G06F9/52 | 分类号: | G06F9/52;G06F9/50 |
代理公司: | 深圳中一联合知识产权代理有限公司 44414 | 代理人: | 翁唱玲 |
地址: | 200120 上海市浦*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 资源 访问 自旋 实现 方法 装置 设备 | ||
本申请适用于计算机技术领域,提供了一种资源访问时自旋锁的实现方法,包括:获取资源访问请求,根据目标资源的标识锁定目标资源对应的自旋锁;若自旋锁锁定失败且循环次数小于预设循环阈值,则循环次数加1,并返回执行根据所述目标资源的标识锁定所述目标资源对应的自旋锁;若所述自旋锁锁定成功,则对所述目标资源执行与所述资源访问请求对应的访问操作。上述方案,设定预设循环阈值,若自旋锁锁定失败且循环次数小于预设循环阈值,则循环次数加1,并返回执行根据目标资源的标识锁定目标资源对应的自旋锁,自旋锁首先自旋一定次数,尝试获取锁,自旋超过一定次数,不再获取锁,避免了自旋锁一直自旋等待,造成中央处理器资源争抢的情况。
技术领域
本申请属于计算机技术领域,尤其涉及一种资源访问时自旋锁的实现方法、装置及设备。
背景技术
在进行资源访问时,为了保证共享资源的一致性,通常使用资源锁的对多线程或者进程进行控制。当临界区范围比较大,访问临界区共享资源发生冲突概率会比较大,获取锁的等待时间会比较长,这种场合可以采用互斥锁。当临界区范围比较小,线程访问临界区共享资源发生冲突的概率比较小,获取锁的等待时间也会比较短,这种场合可以采用自旋锁。
但是,当临界区范围较小,但是共享资源的访问冲突较为频繁时,现有的自旋锁或者现有的互斥锁无法很好的进行控制,都会导致中央处理器过度消耗,浪费系统资源。
发明内容
本申请实施例提供了一种资源访问时自旋锁的实现方法、装置及设备,可以解决现有的自旋锁或者现有的互斥锁无法很好的进行控制,都会导致中央处理器过度消耗,浪费系统资源的问题。
第一方面,本申请实施例提供了一种资源访问时自旋锁的实现方法,包括:
获取资源访问请求,所述资源访问请求包括目标资源的标识;
根据所述目标资源的标识锁定所述目标资源对应的自旋锁;
若所述自旋锁锁定失败且循环次数小于预设循环阈值,则循环次数加1,并返回执行根据所述目标资源的标识锁定所述目标资源对应的自旋锁;
若所述自旋锁锁定成功,则对所述目标资源执行与所述资源访问请求对应的访问操作。
进一步地,在所述根据所述目标资源的标识锁定所述目标资源对应的自旋锁之后,还包括:
若所述自旋锁锁定失败且循环次数等于所述预设循环阈值,则将所述资源访问请求对应的任务放入预设中央处理器CPU调度队列。
进一步地,在所述若所述自旋锁锁定失败且循环次数等于所述预设循环阈值,则将所述资源访问请求对应的任务放入预设中央处理器CPU调度队列之后,还包括:
若所述CPU处于预设状态,则返回所述根据所述目标资源的标识锁定所述目标资源对应的自旋锁。
进一步地,在所述根据所述目标资源的标识锁定所述目标资源对应的自旋锁之前,还包括:
获取自旋锁初始化策略;
根据所述自旋锁初始化策略初始化自旋锁的状态信息;所述状态信息用于标识所述自旋锁是否锁定。
进一步地,在所述若所述自旋锁锁定成功,则对所述目标资源执行与所述资源访问请求对应的访问操作之后,还包括:
当所述资源访问请求对应的访问操作执行完成时,将所述自旋锁的状态信息恢复为初始值。
进一步地,在所述当所述资源访问请求对应的访问操作执行完成时,将所述自旋锁的状态信息恢复为初始值之后,还包括:
当检测到所述目标资源被删除时,销毁所述自旋锁及其状态信息。
第二方面,本申请实施例提供了一种资源访问时自旋锁的实现装置装置,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海金仕达软件科技有限公司,未经上海金仕达软件科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010697107.1/2.html,转载请声明来源钻瓜专利网。