C C++多线程编程:自旋锁_c++自旋锁(1)

  1. 初始化:使用 pthread_spin_init 函数初始化一个自旋锁:
int pthread_spin_init(pthread_spinlock_t *lock, int pshared);

其中 lock 是指向要初始化的自旋锁的指针,pshared 是一个标志,表示这个自旋锁是否应该被多个进程共享。如果这个自旋锁只在一个进程的线程之间共享,应该设置为 PTHREAD_PROCESS_PRIVATE;如果在多个进程间共享,设置为 PTHREAD_PROCESS_SHARED。函数成功时返回 0,否则返回一个错误码。

  1. 销毁:使用 pthread_spin_destroy 函数销毁一个自旋锁:
int pthread_spin_destroy(pthread_spinlock_t *lock);

其中 lock 是指向要销毁的自旋锁的指针。当一个自旋锁被销毁后,再次对它的操作都是未定义的,除非再次对它进行初始化。函数成功时返回 0,否则返回一个错误码。

  1. 加锁:使用 pthread_spin_lock 函数尝试获取一个自旋锁:
int pthread_spin_lock(pthread_spinlock_t *lock);

其中 lock 是指向要获取的自旋锁的指针。如果自旋锁已经被其他线程占有,调用线程将一直等待,直到能够获取锁。函数成功时返回 0,否则返回一个错误码。

  1. 尝试加锁:使用 pthread_spin_trylock 函数尝试获取一个自旋锁:
int pthread_spin_trylock(pthread_spinlock_t *lock);

其中 lock 是指向要获取的自旋锁的指针。如果自旋锁已经被其他线程占有,函数立即返回,并不会等待。函数成功时返回 0,如果自旋锁已经被占有,返回 EBUSY,其他错误返回相应错误码。

  1. 解锁:使用 pthread_spin_unlock 函数释放一个自旋锁:
int pthread_spin_unlock(pthread_spinlock_t *lock);

其中 lock 是指向要释放的自旋锁的指针。函数成功时返回 0,否则返回一个错误码。

总的来说,使用自旋锁时需要注意,长时间持有自旋锁或者在持有自旋锁的情况下执行输入/输出操作或者可能阻塞的操作,都可能导致其他线程长时间等待,从而降低程序的性能。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
std::atomic_bool是C++14中的原子布尔类型。它提供了原子操作,以确保多线程环境下的安全性。它可以用于实现锁、同步和并发算法等。使用std::atomic_bool可以保证对布尔类型的读写操作在多线程环境中是原子的,即不会发生竞态条件。 在C++14中,std::atomic_bool比std::atomic_flag功能更全,可以使用非原子的bool来赋值和初始化。例如,你可以这样使用std::atomic_bool: std::atomic_bool b(true); b = false; 这样就可以对b进行原子的赋值操作。 需要注意的是,std::atomic_flag由于限制性甚至不能用作一个通用的布尔标识,所以最好还是使用std::atomic_bool。在C语言中,也可以使用自旋锁来实现多线程的同步。以下是一个使用自旋锁实现的例子: #include <thread> #include <vector> #include <iostream> #include <atomic> std::atomic_flag lock = ATOMIC_FLAG_INIT; void f(int n) { for (int cnt = 0; cnt < 5; cnt++) { while (lock.test_and_set(std::memory_order_acquire)) ; // 自旋 std::cout << "Thread " << n << " count:" << cnt << std::endl; lock.clear(std::memory_order_release); // 释放锁 } } int main(int argc, char* argv[]) { std::vector<std::thread> v; for (int n = 0; n < 4; n++) { v.emplace_back(f, n); //使用参数进行初始化 } for (auto& t : v) { t.join(); //等待线程结束 } system("pause"); return 0; } 这个例子中,使用std::atomic_flag作为锁,通过test_and_set()和clear()函数来获得锁和释放锁。 总结来说,std::atomic_bool是C++14中的原子布尔类型,可以用于多线程环境下的安全操作。在C语言中,可以使用自旋锁来实现多线程的同步。<span class="em">1</span><span class="em">2</span><span class="em">3</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值