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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

读进程和写进程同步设计_浅谈unix进程进程间通信IPC原理

發布時間:2023/12/15 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 读进程和写进程同步设计_浅谈unix进程进程间通信IPC原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

什么是進程進程間通信

進程間通信即為不同進程之間通信,進程同步是進程間通信的一種

unix進程間通信的分類有哪些

System V進程間通信方式包含:

  • System V消息隊列
  • System V信號量
  • System V共享內存
  • UNIX進程間通信方式包含:

  • 匿名管道
  • 命名管道
  • 信號
  • POSIX進程間通信包含

  • posix消息隊列
  • posix信號量
  • posix共享內存
  • UNIX域套接字(UDS):

  • UNIX Domain Socket
  • UNIX域socket實現本地進程間通信,需要一個進程作為服務器端,一個進程作為客戶端,使用方法有點像socket網絡,但又不經過網絡底層的那些東西。與網絡編程最不一樣的地方是服務器端bind的時候用的是sockaddr_un結構,客戶端connect的時候用的也是sockaddr_un結構,而不是sockaddr_in或sockaddr。而對于sockaddr_un結構,重點是給它提供一個bind()函數生成的socket類型文件的路徑,即sockaddr_un.sun_path的值。并且客戶端與服務器端的這個sockaddr_un結構的sun_path是一致的,通常這個路徑是眾所眾知的,就像百度的域名那樣。

    經過bind,listen,accept,和connect后,兩進程就通過讀寫socket文件描述符來通信,具體是服務器端讀寫accept返回的socket文件描述符,客戶端讀寫經過connect處理后的文件描述符。

    linux進程間通信的分類有哪些

  • 管道(Pipe):管道可用于具有親緣關系進程間的通信,允許一個進程和另一個與它有共同祖先的進程之間進行通信。底層通過文件共享。
  • 命名管道(named pipe):命名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關系進程間的通信。命名管道在文件系統中有對應的文件名。命名管道通過命令mkfifo或系統調用mkfifo來創建。底層通過文件共享。
  • 信號(Signal):信號是比較復雜的通信方式,用于通知接受進程有某種事件發生,除了用于進程間通信外,進程還可以發送信號給進程本身;linux除了支持Unix早期信號語義函數sigal外,還支持語義符合Posix.1標準的信號函數sigaction(實際上,該函數是基于BSD的,BSD為了實現可靠信號機制,又能夠統一對外接口,用sigaction函數重新實現了signal函數)。
  • 消息(Message)隊列:消息隊列是消息的鏈接表,包括Posix消息隊列system V消息隊列。有足夠權限的進程可以向隊列中添加消息,被賦予讀權限的進程則可以讀走隊列中的消息。消息隊列克服了信號承載信息量少,管道只能承載無格式字節流以及緩沖區大小受限等缺點。通過內存共享。
  • 共享內存:使得多個進程可以訪問同一塊內存空間,是最快的可用IPC形式。是針對其他通信機制運行效率較低而設計的。往往與其它通信機制,如信號量結合使用,來達到進程間的同步及互斥。
  • 內存映射(mapped memory):內存映射允許任何多個進程間通信,每一個使用該機制的進程通過把一個共享的文件映射到自己的進程地址空間來實現它。
  • 信號量(semaphore):主要作為進程間以及同一進程不同線程之間的同步手段。
  • 套接口(Socket):更為一般的進程間通信機制,可用于不同機器之間的進程間通信。起初是由Unix系統的BSD分支開發出來的,但現在一般可以移植到其它類Unix系統上:Linux和System V的變種都支持套接字。
  • 各個通信方式比較

  • 管道:速度慢。容量有限,僅僅有父子進程能通訊
  • FIFO:不論什么進程間都能通訊,但速度慢
  • 消息隊列:容量受到系統限制,且要注意第一次讀的時候,要考慮上一次沒有讀完數據的問題
  • 信號量:不能傳遞復雜消息,僅僅能用來同步
  • 共享內存區:能夠非常easy控制容量,速度快,但要保持同步,比方一個進程在寫的時候。還有一個進程要注意讀寫的問題,相當于線程中的線程安全。當然。共享內存區相同能夠用作線程間通訊,只是沒這個必要,線程間本來就已經共享了同一進程內的一塊內存
  • 總結

    以上是生活随笔為你收集整理的读进程和写进程同步设计_浅谈unix进程进程间通信IPC原理的全部內容,希望文章能夠幫你解決所遇到的問題。

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