有名信號量sem_open和內存信號量sem_init創建信號量的區別?
分類: C/C++
sem_t *sem sem_open(const char *name, int oflag, .../*mode_t mode,unsinged int value)?;
int sem_init(sem_t *sem,int shared, unsigned?int value);
區別:
1.創建有名信號量必須指定一個與信號量相關鏈的文件名稱,這個name通常是文件系統中的某個文件。
? 基于內存的信號量不需要指定名稱
2.有名信號量sem 是由sem_open分配內存并初始化成value值
? 基于內存的信號量是由應用程序分配內存,有sem_init初始化成為value值。如果shared為1,則分配的信號量應該在共享內存中。
3.sem_open不需要類似shared的參數,因為有名信號量總是可以在不同進程間共享的
? 而基于內存的信號量通過shared參數來決定是進程內還是進程間共享,并且必須指定相應的內存
4.基于內存的信號量不使用任何類似于O_CREAT標志的東西,也就是說,sem_init總是初始化信號量的值,因此,對于一個給定的信號量,我們必須小心保證只調用sem_init一次,對于一個已經初始化過的信號量調用sem_init,結果是未定義的。
5.內存信號量通過sem_destroy刪除信號量,有名信號量通過sem_unlink刪除
int sem_init(sem_t *sem,int shared, unsigned?int value);
區別:
1.創建有名信號量必須指定一個與信號量相關鏈的文件名稱,這個name通常是文件系統中的某個文件。
? 基于內存的信號量不需要指定名稱
2.有名信號量sem 是由sem_open分配內存并初始化成value值
? 基于內存的信號量是由應用程序分配內存,有sem_init初始化成為value值。如果shared為1,則分配的信號量應該在共享內存中。
3.sem_open不需要類似shared的參數,因為有名信號量總是可以在不同進程間共享的
? 而基于內存的信號量通過shared參數來決定是進程內還是進程間共享,并且必須指定相應的內存
4.基于內存的信號量不使用任何類似于O_CREAT標志的東西,也就是說,sem_init總是初始化信號量的值,因此,對于一個給定的信號量,我們必須小心保證只調用sem_init一次,對于一個已經初始化過的信號量調用sem_init,結果是未定義的。
5.內存信號量通過sem_destroy刪除信號量,有名信號量通過sem_unlink刪除