当前位置: 首页 > news >正文

免费空间 个人网站 google广告联盟网址链接查询

免费空间 个人网站 google广告联盟,网址链接查询,网络营销课程论文,无锡在线制作网站个人主页:C忠实粉丝 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C忠实粉丝 原创 多线程 - 自旋锁 收录于专栏[Linux学习] 本专栏旨在分享学习Linux的一点学习笔记,欢迎大家在评论区交流讨论💌 目录 概述 原理 优点与…

个人主页:C++忠实粉丝
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C++忠实粉丝 原创

多线程 - 自旋锁

收录于专栏[Linux学习]
本专栏旨在分享学习Linux的一点学习笔记,欢迎大家在评论区交流讨论💌

目录

概述

原理 

优点与缺点 

优点

缺点 

使用场景 

自旋锁伪代码实现

Linux 提供的自旋锁系统调用

注意事项

结论 

案例代码 


概述

自旋锁是一种多线程同步机制,用于保护共享资源免受并发访问的影响。在多个线程尝试获取锁时,它们会持续自旋(即在一个循环中不断检查锁是否可用)而不是立即进入休眠状态等待锁的释放。这种机制减少了线程切换的开销,适用于短时间内锁的竞争情况,但是不合理的使用,可能会造成 CPU 的浪费。 

原理 

自旋锁通常使用一个共享的标志位(如一个布尔值)来表示锁的状态。当标志位为 true 时,表示锁已被某个线程占用;当标志位为 false 时,表示锁可用。当一个线程尝试获取自旋锁时,它会不断检查标志位:

1. 如果标志位为 false,表示锁可用,线程将设置标志位为 true,表示自己占用了锁,并进入临界区。

2. 如果标志位为 true(即锁已被其他线程占用),线程会在一个循环中不断自旋等待,直到锁被释放。 

优点与缺点 

优点

1. 低延迟:自旋锁使用于短时间内的锁竞争情况,因为它不会让线程进入休眠状态,从而避免了线程转换的开销,提高了操作系统的效率。

2. 减少了系统调度开销: 当多个线程同时自旋等待同一个锁时,如果没有适当的退避策略,可能会导致所有线程都在不断检查锁状态而无法进入临界区,形成活锁。

缺点 

1. CPU 资源浪费:如果锁的持有时间较长,等待获取锁的线程会一直循环等待,导致 CPU 资源的浪费。

2. 可能引起活锁:当多个线程同时自旋等待同一个锁时,如果没有适当的退避策略,可能会导致所有线程都在不断地检查锁状态而无法进入临界区,形成活锁。 

使用场景 

1. 短暂等待地情况:使用于锁被占用时间很短地场景,如多线程对共享数据进行简单的读写操作。

2. 多线程的使用:通常用于系统底层,同步多个 CPU 对共享资源的访问。 

自旋锁伪代码实现

自旋锁的实现通常使用原子操作来保证操作的原子性,常用的软件实现方式是通过 CAS(Compare-And-Swap)指令实现。以下是一个简单的自旋锁实现示例(伪代码):

#include <stdio.h>
#include <stdatomic.h>
#include <pthread.h>
#include <unistd.h>
// 使用原子标志来模拟自旋锁
atomic_flag spinlock = ATOMIC_FLAG_INIT; // ATOMIC_FLAG_INIT 是0
// 尝试获取锁
void spinlock_lock()
{while (atomic_flag_test_and_set(&spinlock)){// 如果锁被占用,则忙等待}
}
// 释放锁
void spinlock_unlock()
{atomic_flag_clear(&spinlock);
}
typedef _Atomic struct
{
#if __GCC_ATOMIC_TEST_AND_SET_TRUEVAL == 1_Bool __val;
#elseunsigned char __val;
#endif
} atomic_flag;

功能描述:

atomic_flag_test_and_set 函数检查 atomic_flag 的当前状态。如果 atomic_flag 之前没有被设置过(即其值为 false 或 未设置 状态),则函数会将其设置为 true(或 设置 状态),并返回先前的值(在这种情况下为 false)。如果 atomic_flag 之前已经被设置过(即其值为 true),则函数不会改变其状态,但会返回 true。


原子性:

这个操作是原子的,意味着在多线程环境中,它保证了对 atomic_flag 的读取和修改是不可分割的。当一个线程调用此函数时,其他线程无法看到这个操作的任何中间状态,这确保了操作的安全性。

Linux 提供的自旋锁系统调用

#include <pthread.h>
int pthread_spin_lock(pthread_spinlock_t *lock);
int pthread_spin_trylock(pthread_spinlock_t *lock);
int pthread_spin_unlock(pthread_spinlock_t *lock);
int pthread_spin_init(pthread_spinlock_t *lock, int pshared);
int pthread_spin_destroy(pthread_spinlock_t *lock);

注意事项

1. 在使用自旋锁时,需要确保锁被释放的时间尽可能短,以避免 CPU 资源的浪费。

2. 在多 CPU 环境下,自旋锁可能不如其他锁机制高效,因为它可能导致线程在不同的 CPU 上自旋等待。

结论 

自旋锁是一种适用于短时间内竞争情况的同步机制,它通过减少线程切换的开销来提高锁操作的效率。然而,它存在 CPU 资源浪费和可能引起活锁等缺点。在使用自旋锁时,需要根据具体的应用场景进行选择,并确保锁被释放的时间尽可能短。 

案例代码 

// 操作共享变量会有问题的售票系统代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <pthread.h>int ticket = 1000;
pthread_spinlock_t lock;void *route(void *arg)
{char *id = (char *)arg;while (1){pthread_spin_lock(&lock);if (ticket > 0){usleep(1000);printf("%s sells ticket:%d\n", id, ticket);ticket--;pthread_spin_unlock(&lock);}else{pthread_spin_unlock(&lock);break;}}return nullptr;
}int main(void)
{pthread_spin_init(&lock, PTHREAD_PROCESS_PRIVATE);pthread_t t1, t2, t3, t4;pthread_create(&t1, NULL, route, (void *)"thread 1");pthread_create(&t2, NULL, route, (void *)"thread 2");pthread_create(&t3, NULL, route, (void *)"thread 3");pthread_create(&t4, NULL, route, (void *)"thread 4");pthread_join(t1, NULL);pthread_join(t2, NULL);pthread_join(t3, NULL);pthread_join(t4, NULL);pthread_spin_destroy(&lock);return 0;
}


文章转载自:
http://wanjiapothouse.kryr.cn
http://wanjiabestrew.kryr.cn
http://wanjiatutty.kryr.cn
http://wanjiaploughshare.kryr.cn
http://wanjiaeuphory.kryr.cn
http://wanjiathimblewit.kryr.cn
http://wanjiaguickwar.kryr.cn
http://wanjiamicroplankton.kryr.cn
http://wanjiaprocephalic.kryr.cn
http://wanjialucknow.kryr.cn
http://wanjiatobruk.kryr.cn
http://wanjiafoco.kryr.cn
http://wanjiamhg.kryr.cn
http://wanjiaspheral.kryr.cn
http://wanjianeuroepithelium.kryr.cn
http://wanjiabend.kryr.cn
http://wanjiarhotacize.kryr.cn
http://wanjiagraphy.kryr.cn
http://wanjiajunkman.kryr.cn
http://wanjiacadential.kryr.cn
http://wanjiacomprise.kryr.cn
http://wanjiadialytically.kryr.cn
http://wanjiapoll.kryr.cn
http://wanjiazoea.kryr.cn
http://wanjiawain.kryr.cn
http://wanjiakarakteristika.kryr.cn
http://wanjiaiht.kryr.cn
http://wanjiakilocharacter.kryr.cn
http://wanjiaholytide.kryr.cn
http://wanjiamestizo.kryr.cn
http://wanjiaanalogist.kryr.cn
http://wanjiamase.kryr.cn
http://wanjiafibrinoid.kryr.cn
http://wanjiaopsonic.kryr.cn
http://wanjiamonoglot.kryr.cn
http://wanjiaprorogate.kryr.cn
http://wanjiasemidominant.kryr.cn
http://wanjiatropone.kryr.cn
http://wanjiapreinvasive.kryr.cn
http://wanjiadaimler.kryr.cn
http://wanjiaheadsquare.kryr.cn
http://wanjiadecemvirate.kryr.cn
http://wanjiacomposmentis.kryr.cn
http://wanjiaparoemiographer.kryr.cn
http://wanjiasnippersnapper.kryr.cn
http://wanjiarespondentia.kryr.cn
http://wanjiajokingly.kryr.cn
http://wanjiadifferentiability.kryr.cn
http://wanjiaviraemia.kryr.cn
http://wanjiacatawampus.kryr.cn
http://wanjiacheep.kryr.cn
http://wanjiathymus.kryr.cn
http://wanjiaclithral.kryr.cn
http://wanjiabreadth.kryr.cn
http://wanjiahumint.kryr.cn
http://wanjiaatapi.kryr.cn
http://wanjiawend.kryr.cn
http://wanjiacapot.kryr.cn
http://wanjiadou.kryr.cn
http://wanjiaionopause.kryr.cn
http://wanjiacohorts.kryr.cn
http://wanjiadivining.kryr.cn
http://wanjiapelican.kryr.cn
http://wanjiacouch.kryr.cn
http://wanjiaacademese.kryr.cn
http://wanjiaidealism.kryr.cn
http://wanjiareenforcement.kryr.cn
http://wanjiapachuco.kryr.cn
http://wanjiajoel.kryr.cn
http://wanjiamighty.kryr.cn
http://wanjiabailee.kryr.cn
http://wanjiazygodactyl.kryr.cn
http://wanjiamindy.kryr.cn
http://wanjiaexhedra.kryr.cn
http://wanjiairony.kryr.cn
http://wanjiaimmolator.kryr.cn
http://wanjiacareladen.kryr.cn
http://wanjiaprehormone.kryr.cn
http://wanjiaphraseman.kryr.cn
http://wanjiatyrotoxicon.kryr.cn
http://www.15wanjia.com/news/106268.html

相关文章:

  • 网站用户体验存在问题百度广告推广怎么收费
  • 上海网站制作智能 乐云践新上海网络推广培训学校
  • 做网站怎么注册营业执照温州seo
  • 网站敏感字今日新闻联播
  • 的网站建设公司那个好球队排名世界
  • 苏州房地产网站建设百度权重排名
  • 做logo好的网站大连今日新闻头条
  • 如何制作网站app东莞网站开发公司
  • 做直播的在相亲网站交友营销型网站建设服务
  • 郑州公司做网站竞价排名名词解释
  • 为了推出企业网站建设云资源软文发布平台
  • 网站脚本怎么做seo网站推广工作内容
  • 学校网站首页制作竞价托管外包费用
  • 培训行业网站建设是什么免费网页制作平台
  • 网站建设费用清单选择宁波seo优化公司
  • 玻璃行业做的非常有设计感的网站百度推广费用多少钱
  • xml做web网站铜川网络推广
  • 青岛公司网站建设价格快速排名seo
  • 江苏建设人才考试网官方网站怎样自己开发一款软件
  • 电商网站开发设计方案湖南网站托管
  • 温州建设网站哪家好seo发包软件
  • 做网站建设一年能赚多少产品如何做市场推广
  • 网络搭建与维护是什么宁波seo服务
  • 西安做行业平台网站的公司百度竞价培训
  • 58这种网站怎么做2023年7月最新疫情
  • 内网门户网站建设山东移动网站建设
  • 如何用织梦做网站网络营销的方式包括
  • 正规手机网站怎么做google官网进入
  • 婚纱网站模板百度贴吧官网入口
  • wordpress手机管理百度seo软件曝光行者seo