Pthread_mutex_t鎖

[cpp] view plain copy
  1. linux下爲了多線程同步,通常用到鎖的概念。  
  2. posix下抽象了一個鎖類型的結構:ptread_mutex_t。通過對該結構的操作,來判斷資源是否可以訪問。顧名思義,加鎖(lock)後,別人就無法打開,只有當鎖沒有關閉(unlock)的時候才能訪問資源。  
  3. 它主要用如下5個函數進行操作。  
  4. 1:pthread_mutex_init(pthread_mutex_t * mutex,const pthread_mutexattr_t *attr);  
  5. 初始化鎖變量mutex。attr爲鎖屬性,NULL值爲默認屬性。  
  6. 2:pthread_mutex_lock(pthread_mutex_t *mutex);加鎖  
  7. 3:pthread_mutex_tylock(pthread_mutex_t *mutex);加鎖,但是與2不一樣的是當鎖已經在使用的時候,返回爲EBUSY,而不是掛起等待。  
  8.   
  9. 4:pthread_mutex_unlock(pthread_mutex_t *mutex);釋放鎖  
  10. 5:pthread_mutex_destroy(pthread_mutex_t *mutex);使用完後釋放  
  11.   
  12. 下面經典例子爲創建兩個線程對sum從1加到100。前面第一個線程從1-49,後面從50-100。主線程讀取最後的加值。爲了防止資源競爭,用了pthread_mutex_t 鎖操作。  
  13. #include<stdlib.h>  
  14. #include<stdio.h>  
  15. #include<unistd.h>  
  16. #include<pthread.h>  
  17. typedef struct ct_sum  
  18. int sum;  
  19.   pthread_mutex_t lock;  
  20. }ct_sum;  
  21. void * add1(void * cnt)  
  22. {       
  23.      
  24.     pthread_mutex_lock(&(((ct_sum*)cnt)->lock));  
  25.     int i;  
  26.         for( i=0;i<50;i++)  
  27.         {(*(ct_sum*)cnt).sum+=i;  
  28.           
  29.         }  
  30.     pthread_mutex_unlock(&(((ct_sum*)cnt)->lock));  
  31.     pthread_exit(NULL);  
  32.     return 0;  
  33. }  
  34. void * add2(void *cnt)  
  35. {       
  36.     int i;  
  37.     cnt= (ct_sum*)cnt;  
  38.     pthread_mutex_lock(&(((ct_sum*)cnt)->lock));  
  39.     for( i=50;i<101;i++)  
  40.     {    (*(ct_sum*)cnt).sum+=i;  
  41.           
  42.     }  
  43.     pthread_mutex_unlock(&(((ct_sum*)cnt)->lock));  
  44.     pthread_exit(NULL);  
  45.     return 0;  
  46. }  
  47.   
  48.   
  49. int main(void)  
  50. int i;  
  51.   pthread_t ptid1,ptid2;  
  52.   int sum=0;  
  53.   ct_sum cnt;  
  54.   pthread_mutex_init(&(cnt.lock),NULL);  
  55.   cnt.sum=0;  
  56.   
  57.   pthread_create(&ptid1,NULL,add1,&cnt);  
  58. pthread_create(&ptid2,NULL,add2,&cnt);  
  59.    
  60.  pthread_mutex_lock(&(cnt.lock));  
  61.  printf("sum %d\n",cnt.sum);  
  62.  pthread_mutex_unlock(&(cnt.lock));  
  63.   
  64.  pthread_join(ptid1,NULL);  
  65.  pthread_join(ptid2,NULL);  
  66.   pthread_mutex_destroy(&(cnt.lock));  
  67.   return 0;  
  68. }
發佈了57 篇原創文章 · 獲贊 10 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章