#include<stdio.h>
include<pthread.h>
int g_var = 10;
void* thread_worker1(void* agr)
{
while(1)
{
printf("thread_worker1 tid:[%lu],g_var++=%d\n",pthread_self(),g_var++);
sleep(2);
}
return NULL;
}
void * thread_worker2(void*agr)
{
while(1)
{
printf("thread_worker2 tid:[%lu],g_var++=%d\n",pthread_self(),g_var++);
sleep(2);
}
return NULL;
}
int main(int argc,char *argv[])
{
pthread_t tid1;
pthread_t tid2;
printf("g_var= %d\n",g_var);
pthread_create(&tid1,NULL,thread_worker1,NULL);
pthread_create(&tid2,NULL,thread_worker2,NULL);
while(1)
{
printf("master thread run: g_var++ =%d\n",g_var++);
sleep(2);
}
return 0;
}
运行结果如下
ligang@centos6 ~]$ gcc pthread_1.c -lpthread
[ligang@centos6 ~]$ ./a.out
g_var= 10
thread_worker1 tid:[140334780217088],g_var++=10
thread_worker2 tid:[140334769727232],g_var++=12
master thread run: g_var++ =11
thread_worker1 tid:[140334780217088],g_var++=13
thread_worker2 tid:[140334769727232],g_var++=14
thread_worker2 tid:[140334769727232],g_var++=14
#include<stdio.h>
#include<pthread.h>
#include <unistd.h>
#include <pthread.h>
int g_var = 10;
pthread_mutex_t mutex;
void* thread_worker1(void* agr)//参数agr不可少
{
while(1)
{
pthread_mutex_lock(&mutex);//阻塞锁
printf("thread_worker1 tid:[%lu],g_var++=%d\n",pthread_self(),g_var++);
pthread_mutex_unlock(&mutex);//解锁
sleep(2);
}
return NULL;
}
void * thread_worker2(void*agr)
{
while(1)
{
pthread_mutex_lock(&mutex);
printf("thread_worker2 tid:[%lu],g_var++=%d\n",pthread_self(),g_var++);
pthread_mutex_unlock(&mutex);
sleep(2);
}
return NULL;
}
int main(int argc,char *argv[])
{
//daemon(0,0);
pthread_t tid1;
pthread_t tid2;
printf("g_var= %d\n",g_var);
pthread_create(&tid1,NULL,thread_worker1,NULL);
pthread_create(&tid2,NULL,thread_worker2,NULL);
while(1)
{
pthread_mutex_lock(&mutex);
printf("master thread run: g_var++ =%d\n",g_var++);
pthread_mutex_unlock(&mutex);
sleep(2);
}
return 0;
}
加锁运行之后 结果:
如果不在前端输出,则用daemon(0,0) 放入后台执行。该程序有问题 就是全局变量的值溢出。所以要控制执行时间,做溢出判断