sem_open 信號量操做

sem_open,計算機用語。意思是建立並初始化有名信號量或打開一個已存在的有名信號量html

 

sem_init:初始化信號量sem_t,初始化的時候能夠指定信號量的初始值,以及是否能夠在多進程間共享。 sem_wait:一直阻塞等待直到信號量>0。 sem_timedwait:阻塞等待若干時間直到信號量>0。 sem_post:使信號量加1。 sem_destroy:釋放信號量。web

 

轉:http://www.elecfans.com/emb/20190402898866.htmlpost

分類:內核信號量與用戶信號量,用戶信號量分爲POXIS信號量和SYSTEMV信號量,POXIS信號量分爲有名信號量和無名信號量spa

內核信號量:線程

  • #include
  • 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信號量:htm

  • #include
  • 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無名信號量blog

  • #include
  • 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生效
相關文章
相關標籤/搜索