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

正规的网站制作联系方式wordpress 验证百度网盟

正规的网站制作联系方式,wordpress 验证百度网盟,网站建设公司怎么发展,wordpress用的什么前端1、概念 1.1 定义 自旋锁(Spinlock)是一种特殊的锁机制,当线程尝试获取锁而锁不可用时,线程会进入忙等待(即循环检查锁是否可用),而不是进入睡眠状态。这种机制适用于锁持有时间非常短的场景&…

1、概念

1.1 定义

自旋锁(Spinlock)是一种特殊的锁机制,当线程尝试获取锁而锁不可用时,线程会进入忙等待(即循环检查锁是否可用),而不是进入睡眠状态。这种机制适用于锁持有时间非常短的场景,因为它避免了线程上下文切换的开销。然而,如果锁持有时间较长,自旋锁可能会导致CPU资源的浪费。

1.2 特点

  • 忙等待:自旋锁会在获取锁时不断循环检查锁的状态,直到获取到锁为止。这种忙等待的方式可以减少线程切换的开销,适用于对锁的占用时间较短的情况。
  • 无阻塞:自旋锁不会将线程阻塞,因此适用于对锁的占用时间较短、竞争不激烈的情况。
  • 适用于多核CPU:自旋锁在多核CPU上效果更好,因为在一个核上的线程忙等待时,其他核上的线程可以继续执行。

1.3 应用场景

  • 短期占用:适用于对锁的占用时间较短的情况,避免线程切换的开销。
  • 低竞争:适用于竞争不激烈的情况,避免线程频繁地阻塞和唤醒。
  • 多核CPU:在多核CPU上,自旋锁的效率更高,因为可以充分利用多核并行执行的优势

2、常用接口

2.1 pthread_spin_init

初始化一个自旋锁。

pthread_spin_init(pthread_spinlock_t *lock, int pshared)
  • 入参
    • lock:指向要初始化的自旋锁的指针。
    • pshared:指定锁的共享属性,通常设置为PTHREAD_PROCESS_PRIVATE。
  • 返回值:若成功,返回0;否则返回错误码。

2.2 pthread_spin_lock

获取自旋锁。

pthread_spin_lock(pthread_spinlock_t *lock)
  • 入参
    • lock:指向要获取的自旋锁的指针。
  • 返回值:若成功,返回0;否则返回错误码。

2.3 pthread_spin_trylock

尝试获取自旋锁,如果锁已被其他线程占用,则立即返回。

pthread_spin_trylock(pthread_spinlock_t *lock)
  • 入参
    • lock:指向要尝试获取的自旋锁的指针。
  • 返回值:若成功获取锁,返回0;若锁已被占用,返回EBUSY;其他情况返回错误码。

2.4 pthread_spin_unlock

释放自旋锁。

pthread_spin_unlock(pthread_spinlock_t *lock)
  • 作用:释放自旋锁。
  • 入参
    • lock:指向要释放的自旋锁的指针。
  • 返回值:若成功,返回0;否则返回错误码。

2.5 pthread_spin_destroy

销毁一个已经初始化的自旋锁。

pthread_spin_destroy(pthread_spinlock_t *lock)
  • 作用:销毁一个已经初始化的自旋锁。
  • 入参
    • lock:指向要销毁的自旋锁的指针。
  • 返回值:若成功,返回0;否则返回错误码。

3、编程测试

分别测试使用自旋锁和不使用自旋锁操作全局变量的情况。定义一个全局共享变量shared_resource和两个线程都将访问并修改它。使用pthread_spinlock_t类型的变量spinlock作为自旋锁。在thread_function函数中,线程首先尝试使用pthread_spin_lock函数获取自旋锁,如果锁不可用,线程会忙等待直到锁可用。获取锁后,线程访问并修改共享资源,然后释放锁,使用pthread_spin_unlock函数。最后,主线程等待两个工作线程完成,并输出最终的共享资源值。

先将自旋锁代码注释掉,测试程序:

#include <stdio.h>  
#include <stdlib.h>  
#include <pthread.h>  // 全局共享变量  
int shared_resource = 0;  // 自旋锁  
pthread_spinlock_t spinlock;  // 线程函数  
void* thread_function(void* arg) 
{  int thread_id = *(int*)arg;  // 尝试获取自旋锁  // pthread_spin_lock(&spinlock);  // 访问共享资源  for (int i = 0; i < 100000; i++) {  shared_resource += 1;  }  printf("Thread %d finished, shared_resource = %d\n", thread_id, shared_resource);  // 释放自旋锁  // pthread_spin_unlock(&spinlock);  return NULL;  
}  int main() 
{  // 初始化自旋锁  if (pthread_spin_init(&spinlock, 0) != 0) {  printf("Spinlock initialization failed\n");  return 1;  }  // 创建两个线程  pthread_t thread1, thread2;  int thread1_id = 1, thread2_id = 2;  if (pthread_create(&thread1, NULL, thread_function, &thread1_id) != 0) {  printf("Thread 1 creation failed\n");  return 1;  }  if (pthread_create(&thread2, NULL, thread_function, &thread2_id) != 0) {  printf("Thread 2 creation failed\n");  return 1;  }  // 等待线程结束  pthread_join(thread1, NULL);  pthread_join(thread2, NULL);  // 销毁自旋锁  pthread_spin_destroy(&spinlock);  printf("Final shared_resource value: %d\n", shared_resource);  return 0;  
}

测试结果异常,结果不可控:

去掉注释测试自旋锁功能:

#include <stdio.h>  
#include <stdlib.h>  
#include <pthread.h>  // 全局共享变量  
int shared_resource = 0;  // 自旋锁  
pthread_spinlock_t spinlock;  // 线程函数  
void* thread_function(void* arg) 
{  int thread_id = *(int*)arg;  // 尝试获取自旋锁  pthread_spin_lock(&spinlock);  // 访问共享资源  for (int i = 0; i < 100000; i++) {  shared_resource += 1;  }  printf("Thread %d finished, shared_resource = %d\n", thread_id, shared_resource);  // 释放自旋锁  pthread_spin_unlock(&spinlock);  return NULL;  
}  int main() 
{  // 初始化自旋锁  if (pthread_spin_init(&spinlock, 0) != 0) {  printf("Spinlock initialization failed\n");  return 1;  }  // 创建两个线程  pthread_t thread1, thread2;  int thread1_id = 1, thread2_id = 2;  if (pthread_create(&thread1, NULL, thread_function, &thread1_id) != 0) {  printf("Thread 1 creation failed\n");  return 1;  }  if (pthread_create(&thread2, NULL, thread_function, &thread2_id) != 0) {  printf("Thread 2 creation failed\n");  return 1;  }  // 等待线程结束  pthread_join(thread1, NULL);  pthread_join(thread2, NULL);  // 销毁自旋锁  pthread_spin_destroy(&spinlock);  printf("Final shared_resource value: %d\n", shared_resource);  return 0;  
}

测试结果正常:

4、总结

本文讲解了Linux线程同步中使用的自旋锁的定义和应用场景,列举了编程中常用的接口,并编写测试用例进行测试。

http://www.yayakq.cn/news/835922/

相关文章:

  • 建站广告民治专业做网站公司
  • 郑州网站推广价格电商网站分析报告
  • 网站平台建设项目检查汇报材料长沙竞价优化
  • 免费创一个网站网络销售推广是做什么的具体
  • 建设工程+质量+协会网站wordpress文字添加图片不显示图片
  • 做网站的公司市场深圳电子商务网站 开发
  • 莱芜拉呱电商运营seo是什么
  • 山东省建设局网站卢松松wordpress博客
  • 长沙网站制作哪家好wordpress comment_author_link
  • logo在线设计网站wordpress专题修改
  • 手机网站设计平台成都响应式网站
  • 做网站的书籍外包工是临时工吗
  • 沈阳网站制作服务门户app网站建设多少钱
  • 网站设计示例产品开发设计流程
  • 可视化课题组网站建设教程网站开发常用颜色
  • 生鲜网站开发wordpress如何加插件
  • 汉语国际网站建设郑州学校网站建设
  • 怎么在网上接网站开发的工作网站内网页标题对百度排名
  • 建设银行南通城区网站10个优秀的网页设计欣赏
  • 精通网站建设 全能建站密码pdf怎么做wap网站
  • 网站开发视频教程前端低代码平台开发
  • 网站运营招聘要求修改wordpress的语言
  • 国外手机网站作图在线制作
  • 网络公司 网站建设网页中的基本元素有哪些
  • 海南网站运营公司在线学习建设网站
  • 南通seo网站价格竞价托管外包服务
  • 行业门户网站惠城网站建设服务
  • 计算机网站建设 是什么意思沈阳市住房和城乡建设厅网站
  • 福田营销型网站建站推广外包知乎推广公司
  • 网站建设吉金手指排名11家在深圳论坛