sem_init sem_post sem_wait

來源:互聯網
上載者:User

訊號量的資料類型為結構sem_t,它本質上是一個長整型的數。函數sem_init()用來初始化一個訊號量。它的原型為:  

extern int sem_init __P ((sem_t *__sem, int __pshared, unsigned int __value));  

sem為指向訊號量結構的一個指標;pshared不為0時此訊號量在進程間共用,否則只能為當前進程的所有線程共用;value給出了訊號量的初始值。  

函數sem_post( sem_t *sem )用來增加訊號量的值。當有線程阻塞在這個訊號量上時,調用這個函數會使其中的一個線程不在阻塞,選擇機制同樣是由線程的調度策略決定的。  

函數sem_wait( sem_t *sem )被用來阻塞當前線程直到訊號量sem的值大於0,解除阻塞後將sem的值減一,表明公用資源經使用後減少。函數sem_trywait ( sem_t *sem )是函數sem_wait()的非阻塞版本,它直接將訊號量sem的值減一。  

函數sem_destroy(sem_t *sem)用來釋放訊號量sem。 

訊號量用sem_init函數建立的,下面是它的說明:
  #include<semaphore.h>
        int sem_init (sem_t *sem, int pshared, unsigned int value);

        這個函數的作用是對由sem指定的訊號量進行初始化,設定好它的共用選項,並指定一個整數類型的初始值。pshared參數控制著訊號量的類型。如果 pshared的值是0,就表示它是當前裡程的局部訊號量;否則,其它進程就能夠共用這個訊號量。我們現在只對不讓進程共用的訊號量感興趣。 (這個參數 受版本影響), pshared傳遞一個非零將會使函數調用失敗。

  這兩個函數控制著訊號量的值,它們的定義如下所示:
  
  #include <semaphore.h>
        int sem_wait(sem_t * sem);
        int sem_post(sem_t * sem);
 
        這兩個函數都要用一個由sem_init調用初始化的訊號量對象的指標做參數。
        sem_post函數的作用是給訊號量的值加上一個“1”,它是一個“原子操作”---即同時對同一個訊號量做加“1”操作的兩個線程是不會衝突的;而同 時對同一個檔案進行讀、加和寫操作的兩個程式就有可能會引起衝突。訊號量的值永遠會正確地加一個“2”--因為有兩個線程試圖改變它。
        sem_wait函數也是一個原子操作,它的作用是從訊號量的值減去一個“1”,但它永遠會先等待該訊號量為一個非零值才開始做減法。也就是說,如果你對 一個值為2的訊號量調用sem_wait(),線程將會繼續執行,介訊號量的值將減到1。如果對一個值為0的訊號量調用sem_wait(),這個函數就 會地等待直到有其它線程增加了這個值使它不再是0為止。如果有兩個線程都在sem_wait()中等待同一個訊號量變成非零值,那麼當它被第三個線程增加 一個“1”時,等待線程中只有一個能夠對訊號量做減法並繼續執行,另一個還將處於等待狀態。
         訊號量這種“只用一個函數就能原子化地測試和設定”的能力下正是它的價值所在。 還有另外一個訊號量函數sem_trywait,它是sem_wait的非阻塞搭檔。

         最後一個訊號量函數是sem_destroy。這個函數的作用是在我們用完訊號量對它進行清理。下面的定義:
          #include<semaphore.h>
          int sem_destroy (sem_t *sem);
          這個函數也使用一個訊號量指標做參數,歸還自己戰勝的一切資源。在清理訊號量的時候如果還有線程在等待它,使用者就會收到一個錯誤。
         與其它的函數一樣,這些函數在成功時都返回“0”。

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <semaphore.h>

sem_t bin_sem;
void *thread_function1(void *arg)
{
 printf("thread_function1--------------sem_wait/n");
 sem_wait(&bin_sem);
 printf("sem_wait/n");
 while (1)
 {
 }
}

void *thread_function2(void *arg)
{
 printf("thread_function2--------------sem_post/n");
 sem_post(&bin_sem);
 printf("sem_post/n");
 while (1)
 {
 }
}

 
int main()
{
 int res;
 pthread_t a_thread;
 void *thread_result;
 
 res = sem_init(&bin_sem, 0, 0);
 if (res != 0)
 {
  perror("Semaphore initialization failed");
 }
  printf("sem_init/n");
 res = pthread_create(&a_thread, NULL, thread_function1, NULL);
 if (res != 0)
 {
  perror("Thread creation failure");
 }
 printf("thread_function1/n");
 sleep (5);
 printf("sleep/n");
 res = pthread_create(&a_thread, NULL, thread_function2, NULL);
 if (res != 0)
 {
  perror("Thread creation failure");
 }
 while (1)
 {
 }
}

sem_init
thread_function1
thread_function1--------------sem_wait
sleep
thread_function2--------------sem_post
sem_wait
sem_post

本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/panpanquan/archive/2010/07/07/5719229.aspx

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.