1、獲取本進程ID pid_t getpid(void)
2、獲取父進程ID pid_t getppid(void)
3、創建子進程 pid_t fork(void)
//被調用一次,卻返回兩次,它可能有三種不同的返回值:
//在父進程中,fork返回新創建的子進程的PID
//在子進程中,fork返回0
//如果出錯,fork返回一個負值
//用fork創建子進程時,子進程和父進程fork後面的代碼是共享的,但子進程的數據空間和堆棧空間都會從父進程得到一個拷貝,二不是共享。
4、創建子進程 pid_t vfork(void)
5、fork()與vfork()比較
(1)fork: 子進程拷貝父進程的數據段 vfork():子進程與父進程共享數據段
(2)fork:父進程與子進程的執行次序不確定 vfork():子進程先運行,父進程後運行
6、exec函數族
//exec用被執行的程序替換調用它的程序
//exec 不會創建一個新進程,它會運行一個程序,用這個運行的程序代碼去替換原有進程的代碼
7、 int exec(const char * path,cosnt char * arg1,.....)
// path :被執行程序名(包含完整路徑)
// arg1.....argn :被執行程序所需的命令行參數,包含程序名。以空指針(NULL)結束。
//execl("/bin/ls","ls","-al","/etc/passwd",(char *) 0);
8、execlp(const char * path,cosnt char * arg1,.....)
// path :被執行程序名(不包含完整路徑,從path環境變量中查找改程序)
// arg1.....argn :被執行程序所需的命令行參數,包含程序名。以空指針(NULL)結束。
//execlp("ls","ls","-al","/etc/passwd",(char *) 0);
9、int execv(const char * path, char *cosnt argv[])
// path :被執行程序名(包含完整路徑)
// argv[]:被執行程序所需的命令行參數數組
char * argv[]={"ls","-al","/etc/passwd",(char *) 0};
execv("/bin/ls",argv);
10、int system(const char * string)
//功能:調用fork產生子進程,有子進程來調用/bin/sh/ -c string 來執行參數string
11、pid_t wait(int *status)
//阻塞改父進程,直到其某個子進程退出。
//#include <sys/wait.h> #include <sys/types.h> wait(NULL);