System V 信號量

一、System V 信號量

1.信號量linux命令

顯示:
ipcs -a  顯示所有共享內核對象
ipcs -s  顯示信號量   s = semphore刪除:
ipcrm -s ID 刪除信號量 

?

二、主要函數應用

1. 函數原型:

#include <sys/sem.h>
int semget(key_t key, int nsems, int flag);

參數:

  • key:信號集的名字
  • nsems:信號集中信號量的個數
  • semflg:由九個權限標志構成,它們的用法和創建文件時用的mode模式標志是一樣的。

?

2. 函數原型:

#include <sys/sem.h>
int semctl(int semid. int semnum, int cmd, ..../*union semun arg*/);

參數:

  • semid:由semget返回的信號集標識碼
  • semnum:信號集中信號量的序號
  • cmd:將要采取的動作(有三個可能取值)
  • 最后一個參數根據命令不同而不同

cmd:

命令說明
SETVAL設置信號量集中信號量的計數值
GETVAL獲取信號集中的信號量的計數值
IPC_STAT對此集合取semid_ds結構,并存儲在arg.buf指向的結構中
IPC_SET在進程有足夠權限的前提下,把信號集中的當前關聯值設置為semid_ds 數據結構中給出的值
IPC_RMID刪除信號集

?

3. 函數原型:

#include <sys/sem.h>
int semop(int semid, struct sembuf semoparray[], size_t nops);

參數:

  • semid:是該信號集量的標識碼ID,也是semget函數的返回值。
  • sops:是一個指向結構體的指針
  • nsops:操作的信號量的個數

?

三、程序清單

#include <sys/sem.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>#define ERR_EXIT(m) do { perror(m), exit(EXIT_FAILURE); }while(0)
union semun
{int val;struct semid_ds *buf;unsigned short *array;    
};int sem_creat(key_t key)
{int semid;semid = semget(key, 1, IPC_CREAT | IPC_EXCL | 0666);if (semid == -1)ERR_EXIT("semget");return semid;
}int sem_open(key_t key)
{int semid;semid = semget(key, 0, 0);if (semid == -1)ERR_EXIT("semget");return semid;
}int sem_setval(int semid, int val)
{union semun su;su.val = val;int ret;ret = semctl(semid, 0, SETVAL, su);if (ret == -1)ERR_EXIT("sem_setval");return 0;
}
int sem_getval(int semid)
{int ret;ret = semctl(semid, 0, GETVAL, 0);if (semid == -1)ERR_EXIT("sem_getval");printf("current val is %d\n", ret);return ret;
}int sem_d(int semid)
{int ret;ret = semctl(semid, 0, IPC_RMID, 0);if (ret == -1)ERR_EXIT("semctl");return 0;
}int sem_p(int semid)
{struct sembuf sb = { 0, -1, 0 };int ret;ret = semop(semid, &sb, 1);if (ret == -1)ERR_EXIT("semop"); return ret;
}int sem_v(int semid)
{struct sembuf sb = { 0, 1, 0 };int ret;ret = semop(semid, &sb, 1);if (ret == -1)ERR_EXIT("semop"); return ret;
}int sem_getmode(int semid)
{union semun su;struct semid_ds sem;su.buf = &sem;int ret = semctl(semid, 0, IPC_STAT, su);if (ret == -1)ERR_EXIT("semctl");printf("currcnt pcrmissions id %o\n", su.buf->sem_perm.mode);return ret;
}int sem_setmode(int semid, char *mode)
{union semun su;struct semid_ds sem;su.buf = &sem;int ret = semctl(semid, 0, IPC_STAT, su);if (ret == -1)ERR_EXIT("semctl");printf("cuttent permissions is %o\n", su.buf->sem_perm.mode);sscanf(mode, "%o", (unsigned int*)&su.buf->sem_perm.mode);ret = semctl(semid, 0, IPC_SET, su);if (ret == -1)ERR_EXIT("semctl");printf("permissins updated...\n");    
}void usage(void)
{fprintf(stderr, "usage\n");fprintf(stderr, "semtool -c\n");fprintf(stderr, "semtool -d\n");fprintf(stderr, "semtool -p\n");fprintf(stderr, "semtool -v\n");fprintf(stderr, "semtool -s <val>\n");fprintf(stderr, "semtool -q\n");fprintf(stderr, "semtool -f\n");fprintf(stderr, "semtool -m <mode>\n");
}int main(int argc, char *argv[])
{int opt;opt = getopt(argc, argv, "cdpvs:gfm:");if (opt == '?')exit(EXIT_FAILURE);if (opt == -1){usage();exit(EXIT_FAILURE);}key_t key = ftok(".", 's');int semid;switch (opt){case'c':sem_creat(key);break;case'p':semid = sem_open(key);sem_p(semid);sem_getval(semid);break;case'v':semid = sem_open(key);sem_v(semid);sem_getval(semid);break;case'd':semid = sem_open(key);sem_d(semid);break;case's':semid = sem_open(key);sem_setval(semid, atoi(optarg));break;case'g':semid = sem_open(key);sem_getval(semid);break;case'f':semid = sem_open(key);sem_getmode(semid);break;case'm':semid = sem_open(key);sem_setmode(semid, argv[2]);break;}return 0;
}

?

四、參考資料

  • getopt函數用法

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/385529.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/385529.shtml
英文地址,請注明出處:http://en.pswp.cn/news/385529.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java進階之光!mysql安裝包安裝教程

我聽到的一些發聲 你們賺的錢已經可以了&#xff1a; 我一個發小是做土木工程的&#xff0c;上海大學博士&#xff0c;參與很多著名建筑的工程&#xff0c;但是從薪資上看&#xff0c;還不如一些稍微像樣的公司的6年多的高級開發。為什么&#xff1f;這就是行業的紅利&#xf…

Java進階學習資料!dockerjar內存

準備好套路 **①自我介紹&#xff1a;**千萬不能筐瓢&#xff0c;一定要牢記&#xff0c;自然流暢地介紹自己的學習經歷、工作經歷、項目經歷、個人優勢等等&#xff1b; **②抽象概念&#xff1a;**當面試官問你是如何理解多線程的時候&#xff0c;你要知道從定義、來源、實…

管道(二)

無名管道 測試代碼&#xff1a; #include <unistd.h> #include <stdlib.h> #include <stdio.h> #include <fcntl.h> #include <string.h>#define ERR_EXIT(m) do { perror(m); exit(EXIT_FAILURE); }while(0) #define TEST_SIZE 68*1024int mai…

Java進階:java字符串定位語句

正文 模塊&#xff08;Module&#xff09;、組件&#xff08;Component&#xff09;、包&#xff08;Package&#xff09;&#xff0c;這些概念對于我們技術同學并不陌生&#xff0c;但并不是所有人都能理解其要義。 深入理解之后&#xff0c;我才發現&#xff0c;其背后的深…

有名管道

一、有名管道 1. 為何提出有名管道的說法&#xff0c;目的是為了克服無名管道的不足之處&#xff1a; 無名管道只能是用于具有親緣關系的進程之間&#xff0c;這就限制了無名管道的使用范圍。有名管道可以使互不相關的兩個進程互相通信&#xff0c;有名管道可以通過路徑名來指…

Java進階:mysql的事務隔離級別面試題

一面&#xff1a; 阿里巴巴面試答案文末可以領取&#xff01; 1. 觸發新生代GC&#xff0c;如果存活對象總量大于survivor區容量&#xff0c;咋辦 2. 如果任務很多&#xff0c;線程池的阻塞隊列會撐爆內存的哪個區域 3. 棧在堆上嗎 4. GC root有哪些 5. 實例變量可以是GC…

有名管道(二)

一、從FIFO中讀取數據&#xff1a; 約定&#xff1a;如果一個進程為了從FIFO中讀取數據而以阻塞的方式打開FIFO&#xff0c;則稱內核為該進程的讀操作設置了阻塞標志。 如果有進程為寫而打開FIIF&#xff08;寫端存在&#xff09;&#xff0c;且當前FIFO內沒有數據&#xff0…

Java面試2021,java數據可視化項目

AOP簡介 AOP (Aspect Oriented Programing) 稱為&#xff1a;面向切面編程&#xff0c;它是一種編程思想。AOP 是 OOP&#xff08;面向對象編程 Object Oriented Programming)的思想延續 AOP采取橫向抽取機制&#xff0c;取代了傳統縱向繼承體系重復性代碼的編寫方式&#xff0…

gcc的使用

一、gcc編譯過程示意圖 分析&#xff1a; hello程序是一個高級&#xff23;語言程序&#xff0c;這種形式容易被人讀懂。為了在系統上運行hello.c程序&#xff0c;每條&#xff23;語句都必須轉化為低級機器指令。然后將這些指令打包成可執行目標文件格式&#xff0c;并以二進…

Java面試2021,java黑馬百度云

線程是否要鎖住同步資源 鎖住 悲觀鎖不鎖住 樂觀鎖 鎖住同步資源失敗 線程是否要阻塞 阻塞不阻塞自旋鎖&#xff0c;適應性自旋鎖 多個線程競爭同步資源的流程細節有沒有區別 不鎖住資源&#xff0c;多個線程只有一個能修改資源成功&#xff0c;其它線程會重試無鎖同一個線…

gdb使用

[sunbinlocalhost ~]$ gcc -Wall -g simple.c -o simple [sunbinlocalhost ~]$ ./simple Entering main ... result[1-100] 5050 result[1-10] 55 Exiting main ... [sunbinlocalhost ~]$ gdb simple 啟動gdb GNU gdb (GDB) Red Hat Enterprise Linux 7.6.1-110.el7 Copyrigh…

oppoJava面試題,java聲明全局變量的關鍵字

螞蟻一面 ??就做了?道算法題&#xff0c;要求兩?時內完成&#xff0c;給了?度為N的有重復元素的數組&#xff0c;要求輸出第10?的數。典型的TopK問題&#xff0c;快排算法搞定。算法題要注意的是合法性校驗、邊界條件以及異常的處理。另外&#xff0c;如果要寫測試?例&…

System V 消息隊列

一、System V 消息隊列 有一個隊列&#xff0c;隊列存放各種消息。每個進程可以把數據封存在消息中&#xff0c;再放入隊列。每個進程都可以拿到消息隊列&#xff0c;再從中取出/放入消息。 消息隊列也有管道一樣的不足&#xff0c;就是每個消息的最大長度是有上限的&#xf…

oppoJava面試題,java連接數據庫詳細步驟

美團一面&#xff08;50分鐘左右&#xff09; 進程和線程死鎖的必要條件網絡&#xff0c;七層協議TCP和UDP的區別hashmap 詳細講一下hashmap底層是如何解決hash沖突的hashmap和linkedhashmap數據庫的索引&#xff0c;為什么推薦自增id&#xff0c;有什么優點MySQL的引擎&#…

基本TCP套接字編程

1. socket函數原型&#xff1a; #include <sys/socket.h> int socket(int domain, int type, int protocol);2. bind函數原型&#xff1a; #include <sys/socket.h> int bind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen);參數&#xff1a; ? st…

oppoJava面試題,騰訊社招三面多久聯系

梳理知識點&#xff0c;是快速提升技術的關鍵 前面講過&#xff0c;快速提升自己的技術硬實力其實是有方法的。大致就是梳理知識點夯實基礎進階深入學習實戰&#xff0c;下面我會一點點跟大家剖析&#xff0c;本文干貨滿滿&#xff0c;大家仔細閱讀。 ①梳理知識必備&#xff1…

oppoJava面試!傳智播客java基礎案例教程

零基礎如何學習Java&#xff1f; 首先&#xff0c;你要明白一點&#xff0c;Java入門不難&#xff01; 無論你是從事哪個行業&#xff0c;興趣一定是最好的老師&#xff0c;也是你學習的動力。 學習方式1&#xff1a;自學 自學模式其實我個人不建議絕大部分的人選擇&#x…

Redis高級項目實戰!北京java編程入門培訓

Dubbo面試專題 JVM面試專題 Java并發面試專題 Kafka面試專題 MongDB面試專題 MyBatis面試專題 MySQL面試專題 Netty面試專題 RabbitMQ面試專題 Redis面試專題 Spring Cloud面試專題 SpringBoot面試專題 zookeeper面試專題 最后 給大家送一個小福利 資料都是免費分享的&#xf…

poll函數

#include <poll.h> int poll(struct pollfd *fds, nfds_t nfds, int timeout);參數&#xff1a; fds&#xff1a;監聽的文件描述符【數組】 struct pllfd {int fd; 待監聽的文件描述符short events; 待監聽的文件描述符對應的監聽事件short revents; 傳入時&…

Redis高級項目實戰,java配置jdk環境時

Spring Security觀后感——手繪思維腦(供參考) Spring Security手繪思維腦圖 手繪的思維導圖&#xff0c;是我自己根據自身的情況讀完這套阿里出品的Spring Security王者晉級文檔之后所繪的&#xff0c;相當于是一個知識的總結與梳理&#xff0c;我將其分為***“核心組件”與“…