Linux 各類訊號量,Linux訊號量

來源:互聯網
上載者:User

Linux 各類訊號量,Linux訊號量

定義:保護共用資源,使得資源在一個時刻只有一個進程(線程)擁有

原理:訊號量值為正時說明空閑,若為0或負值則說明被佔用

分類:核心訊號量與使用者訊號量,使用者訊號量分為POXIS訊號量和SYSTEMV訊號量,POXIS訊號量分為有名訊號量和無名訊號量

核心訊號量:

  • #include<asm/semaphore.h>
  • void sema_init(struct semaphore *sem, int val);
  • void init_MUTEX(struct semaphore *sem); //初始值1
  • void init_MUTEX_LOCKED(struct semaphore *sem); //初始值0
  • void down(struct semaphore *sem); //可睡眠
  • int down_interruptible(struct semaphore *sem); //可中斷
  • int down_trylock(struct semaphore *sem); //m非阻塞
  • void up(struct semaphore *sem);

SYSTEMV訊號量:

  • #include <sys/sem.h>
  • int semget(key_t key, int nsems, int oflag);
  • int semop(int semid, struct sembuf *opsptr, size_t nops);
  • int semctl(int semid, int semum, int cmd,...);

POSIX無名訊號量

  • #include<semaphore.h>
  • sem_t sem;
  • int sem_init(sem_t *sem, int pshared, unsigned int val); //pshared為0則線程間共用,pshared為1則父子進程共用
  • int sem_wait(sem_t *sem); //阻塞
  • int sem_trywait(sem_t *sem); //非阻塞
  • int sem_post(sem_t *sem);
  • int sem_destroy(sem_t *sem);
  • 進程間共用則sem必須放在共用記憶體地區(mmap, shm_open, shmget),父進程的全域變數、堆、棧中儲存是不行的

POSIX有名訊號量

  • sem_t *sem_open(const char *name, int oflag, mode_t mode, int val);
  • int sem_wait(sem_t *sem);
  • int sem_trywait(sem_t *sem);
  • int sem_post(sem_t *sem);
  • int sem_close(sem_t *sem);
  • int sem_unlink(const char *name);
  • 每個open的位置都要close和unlink,但只有最後執行的unlink生效

 

參考文獻:http://blog.csdn.net/qinxiongxu/article/details/7830537#comments

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.