linux - 多進程 總結1

来源:http://www.cnblogs.com/jinfei/archive/2016/08/07/5746867.html
-Advertisement-
Play Games

參考: operatingfocus.bokee.com/3327857.html www.oschina.net/code/snippet_237505_8646 www.cnblogs.com/techdoc/archive/2010/12/22/1913521.html 一.多進程編程里常用的 ...


參考:

operatingfocus.bokee.com/3327857.html

www.oschina.net/code/snippet_237505_8646

www.cnblogs.com/techdoc/archive/2010/12/22/1913521.html

一.多進程編程里常用的函數。

1.pid_t fork();

  創建子進程

2.int execl(const char * path,const char * arg,....);

  path是可執行文件路徑,  頭文件#include<unistd.h>,該文件時傳遞過去的argv(0)、argv[1]……,最後一個參數必須用空指針(NULL)作結束。

3.int execlp(const char * file,const char * arg,……);

  execlp()會從PATH 環境變數所指的目錄中查找符合參數file的文件名,找到後便執行該文件。

4.int execv (const char * path, char * const argv[ ]);

  path是文件路徑

5.pid_t getpid(void);

  getpid()用來取得目前進程的進程識別碼

6.pid_t getppid(void);

   getppid()用來取得目前進程的父進程識別碼。

7.void setsid(void);

如 果調用此函數的進程不是一個進程組的組長,則此函數就會創建一個新會話,該進程變成會話的首進程,然後該進程成為一個新進程組的組長進程,該進程沒有控制 終端。因為會話首進程是具有唯一進程ID的單個進程,所以可以將會話首進程的進程ID視為會話Id。此函數配合umask()可將進程變成守護進程。

8.pid_t wait(int * status);

功能:阻塞該進程,直到其某個子進程退出.

9.pid_t wait (int * status);

  #include<sys/types.h>,#include<sys/wait.h>。wait()會暫時停止目前進程的執行,直到有信號來到或子進程結束。回收僵屍進程

10.pid_t waitpid(pid_t pid,int * status,int options);

  參數 pid 為欲等待的子進程識別碼,其他數值意義如下:

     pid<-1 等待進程組識別碼為 pid 絕對值的任何子進程。      pid=-1 等待任何子進程,相當於 wait()。                  pid=0     等待進程組識別碼與目前進程相同的任何子進程。             pid>0     等待任何子進程識別碼為 pid 的子進程。

  參數 option 可以為 WNOHANG, 如果沒有任何已經結束的子進程則馬上返回, 不予以等待。

二.進程間的通信

 1.信號量

  1)  int sem_wait(sem_t *sem);

  //P操作,若是信號量大於零則減一,否則阻塞在該函數位置等待.

  2)  int sem_post(sem_t *sem);

  //V操作,信號量加一

  3)  sem_t *sem_open(const char *name, int oflag);

  //打開信號量,flag參數與打開普通文件的標記一樣

  4)  sem_t *(const char *name, int oflag,mode_t mode, unsigned int value);

  //創建並打開信號量,value參數指的是信號量的初始值oflag參數可以是0、O_CREAT(創建一個信號燈)或O_CREAT|O_EXCL(如果沒有指定的信號燈就創建),

  其中mode參數指定許可權位(00777).

  5)  int sem_unlink(const char *name);

  //刪除系統創建的信號量

  6)  int sem_close(sem_t *sem);

  //關閉徹底銷毀信號量

 

 2.管道

 

 

  int pipe(int filedis[2]);

  頭文件#include <unistd.h>,參數filedis返回兩個文件描述符:filedes[0]為讀而打開,filedes[1]為寫而打開。filedes[1]的輸出是filedes[0]的輸入。

 

3.記憶體共用

  #include <sys/mman.h>

 

  void *mmap(void *start, size_t length, int prot, int flags,int fd, off_t offset);

 

  int munmap(void *start, size_t length);

  例子:

    p_map = (people*)mmap(NULL,sizeof(people)*10,PROT_READ|PROT_WRITE,MAP_SHARED,fd,0);

    p_map=(people*)mmap(NULL,sizeof(people)*10,PROT_READ|PROT_WRITE,MAP_SHARED|MAP_ANONYMOUS,-1,0);//匿名,適合父子進程之間

    munmap( p_map,sizeof(people)*10 );

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、資料庫操作 create database 資料庫名稱 ——創建drop database 資料庫名稱 ——刪除use 資料庫名稱 ——使用go 兩條SQL語句之間分隔 二、表的操作 create table 表名( 列名 類型 其它,列名 id類型 其它 ) ——使用primary key — ...
  • 1.索引添加索引,設計界面,在任何一列前右鍵--索引/鍵--點擊進入添加某一列為索引 2.視圖 視圖就是我們查詢出來的虛擬表創建視圖:create view 視圖名 as SQL查詢語句,分組,排序,in 等都不能寫視圖的用法: select * from 視圖名 3.SQL編程 定義變數:decl ...
  • mysql簡介 1、什麼是資料庫 ? 資料庫(Database)是按照數據結構來組織、存儲和管理數據的倉庫,它產生於距今六十多年前,隨著信息技術和市場的發展,特別是二十世紀九十年代以後,數據管理不再僅僅是存儲和管理數據,而轉變成用戶所需要的各種數據管理的方式。資料庫有很多種類型,從最簡單的存儲有各種 ...
  • 介紹 本篇文章主要介紹搭建MMM方案以及MMM架構的原理。這裡不介紹主從、主主的搭建方法,MMM方案不適用對數據一致性要求很高的業務。 架構 部署 1.修改hosts 在所有的伺服器中執行相同的操作。 vim /etc/hosts 192.168.137.10 master 192.168.137. ...
  • 24 MySQL sys框架 24 MySQL sys框架... 1 24.1 sys框架的前提條件... 1 24.2 使用sys框架... 2 24.3 sys框架進度報告... 3 24.4 sys框架的對象... 3 24.4.1所有sys下的對象... 3 24.4.2 sys框架的表和觸 ...
  • mysql slowlog 使用與介紹 slow_query_log =1 是否打開 slow_query_log_file = /data/mysql_data/node-1/mysql-slow.log --位置 long_query_time=5 閾值時間 log_output = {file ...
  • CREATE DATABASE IF NOT EXISTS yourdbname DEFAULT CHARSET utf8 COLLATE utf8_general_ci; 在tigase中,發送消息有文本的形式,比如發送emoji表情, 編碼必須採用 utf8mb4 , utf8mb4 is a ...
  • 以前刪除文件經常Move to trash,今天想清空發現根本不知道回收站在哪裡,囧。遂Google之,於是發現在 ~/.local/share/Trash目錄下。 打開目錄看看有什麼東西: Trash下共三個文件夾,很容易看出來files下麵是刪除的文件,info下麵是對應文件的信息,存儲了刪除的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...