#include <iostream>
#include <pthread.h>
using namespace std;
pthread_mutex_t mutex; //~ 创建互斥锁mutex
int share = 0; //~ 共享数据
//~ 线程入口
void * thread_function(void *arg)
{
const int N = 1000000;
for(int i = 0; i < N; ++i)
{
//~ 访问共享数据
pthread_mutex_lock(&mutex);
share++;
pthread_mutex_unlock(&mutex);
}
}
int
main()
{
pthread_mutex_init(&mutex, NULL); //~ 初始化互斥锁mutex
pthread_t thread_id;
void *exit_status;
pthread_create(&thread_id, NULL, thread_function, NULL); //~ 创建新线程
for(int i = 0; i < 10; ++i)
{
usleep(10000); //~ 延时10ms
//~ 访问共享数据
pthread_mutex_lock(&mutex);
cout<<share<<endl;
pthread_mutex_unlock(&mutex);
}
pthread_join(thread_id, &exit_status); //~ 等待线程结束
pthread_mutex_destroy(&mutex); //~ 销毁互斥锁
return 0;
pthread_mutex一例
最新推荐文章于 2025-07-13 22:19:44 发布
本文展示了一个使用C++和POSIX线程的例子,通过互斥锁(mutex)来同步两个线程间的共享数据访问,防止数据竞争。主线程每隔一段时间显示当前共享变量的值,并在一个独立线程中递增该变量。
1371

被折叠的 条评论
为什么被折叠?



