同步--互斥锁与条件变量、读写锁、信号量

本文介绍了同步中的关键概念,包括互斥锁、条件变量和读写锁的使用。互斥锁通过pthread_mutex_*系列函数实现线程间的互斥访问,条件变量允许线程在特定条件满足时唤醒。读写锁允许多个读取线程同时访问资源,而写线程独占资源。最后,讨论了信号量作为更灵活的同步工具,可用于生产者-消费者模型等场景。
摘要由CSDN通过智能技术生成

互斥锁与条件变量

互斥量

1.静态分配互斥量 pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER
2.动态分配互斥量 pthread_mutex_init(&mutex); & pthread_mutex_destory(&mutex);
//操作:
1.pthread_mutex_lock 加锁
2.pthread_mutex_trylock 尝试加锁
3.pthread_mutex_unlock 解锁
4.保证线程正常 / 异常推出时可以释放互斥锁
pthread_cleanup_push
pthread_cleamup_pop
//套路:

threadHandle(){
	pthread_cleanup_push(pthread_mutex_unlock, mutex);
	pthread_mutex_lock(mutex);
	do something...
	pthread_exit(0);
	pthread_cleamup_pop(0);//确认释放互斥锁
}
main(){
	pthread_mutex_t mutex;//动态分配互斥量
	pthread_mutex_init(&mutex,NULL);

	for{;3; }
	pthread_create(&tid[i], NULL, threadHandle, &mutex);
	pthread_join(tid[i], NULL);
	
	pthread_mutex_destory(&mutex);
}

条件变量

线程挂起直到共享数据某些条件满足

1.动态 pthread_cond_t
2.静态
函数:
条件等待 pthread_cond_wait(cond, m

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值