#include <stdlib.h> #include <stdio.h> #include <pthread.h> #include <errno.h> int gnum = 0; int gsub = 100;pthread_mutex_t mutex; pthread_cond_t cond; //條件變量 void pthread_func_1 (void); void pthread_func_2 (void); int main (void) { pthread_t pt_1 = 0; pthread_t pt_2 = 0; int ret = 0; pthread_mutex_init (&mutex, NULL); //默認情況下 互斥初始化后是解鎖狀態可用 pthread_cond_init(&cond,NULL); // //pthread_cond_init(指向pthread_cond_t的指針,屬性設置<NULL>默認屬性) ret = pthread_create (&pt_1, NULL, (void *)pthread_func_1, NULL); if (ret != 0) printf("pthread_1_create"); ret = pthread_create (&pt_2, NULL, (void *)pthread_func_2, NULL); if (ret != 0) printf("pthread_2_create"); pthread_join (pt_1, NULL); pthread_join (pt_2, NULL); printf ("main programme exit!/n"); return 0; } void pthread_func_1 (void) { //int i = 0; printf ("pthread1 start running!\n"); while(gnum <= 100) { pthread_mutex_lock(&mutex); /*注意,這里以防線程的搶占,以造成一個線程在另一個線程sleep時多次訪問互斥資源,所以sleep要在得到互斥鎖后調用*/ sleep (1); while (gnum == 50) { printf("supend thread1!!!\n"); pthread_cond_wait(&cond, &mutex); printf("thread1 restart!!!\n"); gnum++; } gnum++; printf ("gnum=:%d\n",gnum); pthread_mutex_unlock(&mutex); /*釋放互斥鎖*/ } } void pthread_func_2 (void) { printf ("pthread2 start running!\n"); while (gsub >= 0) { pthread_mutex_lock(&mutex);//mutex被鎖住后,線程在此被掛起,等待mutex變為解鎖狀態后,獲得互斥鎖,繼續執行 sleep (1); gsub--; printf ("gsub=:%d\n",gsub); if (gsub == 50) { printf("resume thread1 at gsun = 5\n"); pthread_cond_signal(&cond);//讓掛起的線程繼續執行 } pthread_mutex_unlock(&mutex); } pthread_exit (0); } 線程1和線程2不是應該交替輸出的么?
1 回答

慕蓋茨4494581
TA貢獻1850條經驗 獲得超11個贊
unlock之后休眠一下
pthread_mutex_unlock(&mutex); /*釋放互斥鎖*/
sleep(1);
pthread1 start running!
pthread2 start running!
gnum=:1
gsub=:99
gnum=:2
gsub=:98
gnum=:3
gsub=:97
gnum=:4
gsub=:96
gnum=:5
- 1 回答
- 0 關注
- 75 瀏覽
添加回答
舉報
0/150
提交
取消