日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

实验六 Linux进程编程,Linux系统编程实验六:进程间通信

發布時間:2025/3/20 linux 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 实验六 Linux进程编程,Linux系统编程实验六:进程间通信 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

《Linux系統編程實驗六:進程間通信》由會員分享,可在線閱讀,更多相關《Linux系統編程實驗六:進程間通信(10頁珍藏版)》請在人人文庫網上搜索。

1、實驗六:進程間通信l 實驗目的:學會進程間通信方式:無名管道,有名管道,信號,消息隊列,l 實驗要求:(一)在父進程中創建一無名管道,并創建子進程來讀該管道,父進程來寫該管道(二)在進程中為SIGBUS注冊處理函數,并向該進程發送SIGBUS信號(三)創建一消息隊列,實現向隊列中存放數據和讀取數據l 實驗器材:軟件:安裝了Linux的vmware虛擬機硬件:PC機一臺l 實驗步驟:(一)無名管道的使用1、編寫實驗代碼pipe_rw.c#include #include #include #include #include #include int main()int pipe_fd2;/管道返。

2、回讀寫文件描述符pid_t pid;char buf_r100;char* p_wbuf;int r_num;memset(buf_r,0,sizeof(buf_r);/將buf_r初始化char str1=”parent write1 “holle”;char str2=”parent write2 “pipe”n”;r_num=30;/*創建管道*/if(pipe(pipe_fd)0) /父進程執行代碼/1、父進程先關閉了管道的讀端close(pipe_fd0);/2、向管道寫入字符串數據p_wbuf=&str1;write(pipe_fd1,p_wbuf,sizof(p_wbuf);p_。

3、wbuf=&str2;write(pipe_fd1,p_wbuf,sizof(p_wbuf);/3、關閉寫端,并等待子進程結束后退出close(pipe_fd1);return 0;/*#include #include #include #include #include #include int main()int pipe_fd2;/管道返回讀寫文件描述符pid_t pid;char buf_r100;char* p_wbuf;int r_num;memset(buf_r,0,sizeof(buf_r);/將buf_r初始化char str1=holle;char str2=pipe;r。

4、_num=10;/*創建管道*/if(pipe(pipe_fd)0) /父進程執行代碼close(pipe_fd0);/1、父進程先關閉了管道的讀端p_wbuf=str1;/2、向管道寫入字符串數據write(pipe_fd1,p_wbuf,sizeof(str1);sleep(1);p_wbuf=str2;write(pipe_fd1,p_wbuf,sizeof(str2);close(pipe_fd1);/3、關閉寫端,并等待子進程結束后退出exit(1);/printf(father error!);return 0;*/2、編譯應用程序pipe_rw.c3、運行應用程序子進程先睡兩秒讓。

5、父進程先運行,父進程分兩次寫入“hello”和“pipe”,然后阻塞等待子進程退出,子進程醒來后讀出管道里的內容并打印到屏幕上再退出,父進程捕獲到子進程退出后也退出4、由于fork函數讓子進程完整地拷貝了父進程的整個地址空間,所以父子進程都有管道的讀端和寫端。我們往往希望父子進程中的一個進程寫一個進程讀,那么寫的進程最后關掉讀端,讀的進程最好關閉掉寫端(二)信號處理1、編寫實驗代碼sig_bus.c#include #include #include /1、自定義信號處理函數,處理SIGBUS信號,打印捕捉到信號即可static void signal_handler(int signo)if。

6、(signo =SIGBUS)printf(“n I have get SIGBUS”);exit(EXIT_FAILURE);int main()printf(Waiting for signal SIGBUS n );/2、注冊信號處理函數if(signal(SIGBUS,signal_handler)=SIG_ERR)fprintf(stderr,”cannot handle SIGBUSn”);exit(EXIT_FAILURE);pause();/將進程掛起直到捕捉到信號為止exit(0);return 0;/*#include #include #include #include 。

7、/1、自定義信號處理函數,處理SIGBUS信號,打印捕捉到信號即可static void signal_handler(int signo)if(signo =SIGBUS)printf(I have get SIGBUS);exit(EXIT_FAILURE);int main()printf(Waiting for signal SIGBUS n );/2、注冊信號處理函數if(signal(SIGBUS,signal_handler)=SIG_ERR)fprintf(stderr,cannot handle SIGBUSn);exit(EXIT_FAILURE);pause();/將進程。

8、掛起直到捕捉到信號為止exit(0);return 0;*/用signal系統調用為SIGBUS信號注冊信號處理函數my_func,然后將進程掛起等待SIGBUS信號。所以需要向該進程發送SIGBUS信號才會執行自定義的信號處理函數2、編譯應用程序sig_bus.c3、運行應用程序先先一個終端中運行sig_bus,會看到進程掛起,等待信號然后在另一個終端中,查找到運行sig_bus這個產生的進程號,用kill命令發送SIGBUS信號給這個進程我們可以看到前面掛起的進程在接收到這個信號后的處理用自定義信號處理函數my_func來處理,所以打印了I have get SIGBUS這樣一句話l 上機。

9、報告要求:1、 總結pipe(),signal()的函數定義原型,返回值和參數的意義表頭文件: #include定義函數: int pipe(int filedes2);函數說明(參數): pipe()會建立管道,并將文件描述詞由參數filedes數組返回。filedes0為管道里的讀取端,filedes1則為管道的寫入端。返回值:若成功則返回零,否則返回-1,錯誤原因存于errno中。阻塞問題:當管道中的數據被讀取后,管道為空。一個隨后的read()調用將默認的被阻塞,等待某些數據寫入。功能:管道是一種把兩個進程之間的標準輸入和標準輸出連接起來的機制,從而提供一種讓多個進程間通信的方法,當進。

10、程創建管道時,每次都需要提供兩個文件描述符來操作管道。其中一個對管道進行寫操作,另一個對管道進行讀操作。對管道的讀寫與一般的IO系統函數一致,使用write()函數寫入數據,使用read()讀出數據。表頭文件:#include功 能:設置某一信號的對應動作函數原型:void (*signal(int signum,void(* handler)(int)(int); 或者:typedef void(*sig_t) ( int ); sig_t signal(int signum,sig_t handler);可看成是signal()函數(它自己是帶有兩個參數,一個為整型,一個為函數指針的函數)。

11、,而這個signal()函數的返回值也為一個函數指針,這個函數指針指向一個帶整型參數,并且返回值為void的一個函數。參數說明:第一個參數signum指明了所要處理的信號類型,它可以取除了SIGKILL和SIGSTOP外的任何一種信號。 第二個參數handler描述了與信號關聯的動作,它可以取以下三種值: (1)一個返回值為正數的函數地址此函數必須在signal()被調用前申明,handler中為這個函數的名字。當接收到一個類型為sig的信號時,就執行handler 所指定的函數。這個函數應有如下形式的定義: intfunc(int sig); sig是傳遞給它的唯一參數。執行了signal(。

12、)調用后,進程只要接收到類型為sig的信號,不管其正在執行程序的哪一部分,就立即執行func()函數。當func()函數執行結束后,控制權返回進程被中斷的那一點繼續執行。(2)SIGIGN 這個符號表示忽略該信號,執行了相應的signal()調用后,進程會忽略類型為sig的信號。 (3)SIGDFL 這個符號表示恢復系統對信號的默認處理。 函數說明:signal()會依參數signum 指定的信號編號來設置該信號的處理函數。當指定的信號到達時就會跳轉到參數handler指定的函數執行。當一個信號的信號處理函數執行時,如果進程又接收到了該信號,該信號會自動被儲存而不會中斷信號處理函數的執行,直到。

13、信號處理函數執行完畢再重新調用相應的處理函數。但是如果在信號處理函數執行時進程收到了其它類型的信號,該函數的執行就會被中斷。返回值:返回先前的信號處理函數指針,如果有錯誤則返回SIG_ERR(-1)。 附加說明:在信號發生跳轉到自定的handler處理函數執行后,系統會自動將此處理函數換回原來系統預設的處理方式,如果要改變此操作請改用sigaction()。下面的情況可以產生Signal: 1. 按下CTRL+C產生SIGINT 2. 硬件中斷,如除0,非法內存訪問(SIGSEV)等等 3. Kill函數可以對進程發送Signal 4. Kill命令。實際上是對Kill函數的一個包裝 5.軟件。

14、中斷。如當Alarm Clock超時(SIGURG),當Reader中止之后又向管道寫數據(SIGPIPE),等等命名管道FIFO功能:管道最大的劣勢就是沒有名字,只能用于有一個共同祖先進程的各個進程之間。FIFO代表先進先出,單它是一個單向數據流,也就是半雙工,和管道不同的是:每個FIFO都有一個路徑與之關聯,從而允許無親緣關系的進程訪問。 頭文件:#include #include 函數定義原型:int mkfifo(const char *pathname, mode_t mode);參數:這里pathname是路徑名,mode是sys/stat.h里面定義的創建文件的權限.2、 利用有。

15、名管道FIFO實現類似第一個實驗的功能,一個程序fifo_read.c寫數據”Hi Linux”,另一個程序fifo_write.c讀數據并打印出來。/fifo.read.c#include #include #include #include #include #include #include #include /#define FIFO fifoint main()int fdr,fd;char buf_r=Hi Linuxn;fd=mkfifo(fifo.txt,O_CREAT|O_RDWR|0666);if(fd#include #include #include #include #include #include #include /#define FIFO fifoint main()int fdw,fd;char buf100;memset(buf,0,sizeof(buf);fdw=open(fifo.txt,O_RDONLY);if(fdw0)printf(open error(W)!);exit(-1);/sleep(2);if(read(fdw,buf,100)0)printf(read error(W);exit(-1);printf(n%s,buf);close(fdw);return 0。

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的实验六 Linux进程编程,Linux系统编程实验六:进程间通信的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。