线程的创建与互斥锁

一、创建线程

1、编译链接库

gcc –lpthead

2、定义变量

pthread_t th;

3、创建

int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine) (void *), void *arg);

pthread_create(&th, NULL, fun, arg);

4、子线程

void *fun (void * arg)
{
	return(void)*0;
}

5、主线程等待
在这里插入图片描述

main要等待子线程结束,所以需要join函数,不然就return了:

int pthread_join(pthread_t tid,void **rval);

pthread_join(th, NULL);

二、互斥锁

6、race condition

线程1和线程2都是在用同一把锁,只是说谁先抢到了谁先上锁,然后解锁了,另一个线程才能上锁。

int pthread_mutex_init(pthread_mutex_t *restrict mutex, const
pthread_mutexattr_t *restrict attr);

初始化锁:

pthread_mutex_t lock;
pthread_mutex_init(&lock,  NULL);

在func()里:对fun()上锁解锁

void* func(void* argc)
{
	int pthread_mutex_lock(pthread_mutex_t *mutex);

	int pthread_mutex_unlock(pthread_mutex_t *mutex);
}

三、假共享

多核,内存地址相连比较近的时候会出现假共享:
在这里插入图片描述
进程1是操作results[0]的
进程2是操作results[1]的
但是内核为了方便,把results[0]和results[1]都写入缓存,这样子数据一旦变化,都得变化,造成了运行时间变长。

把数组变大,把线程1的结果和线程2的结果存的原点,就不会出现假共享了

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值