进程控制编程之fork() exec函数族  终止函数

一 进程创建fork()

#include <unistd.h>
 
pid_t fork(void)

功能:创建子进程
   
  fork的奇妙之处在于它被调用一次,却返回两次,它可能有三种不同的返回值:

1、在父进程中,fork返回新创建的子进程的PID;
2、在子进程中,fork返回0;
3、如果出现错误,fork返回一个负值

int main()
{
	
	pid_t pid = fork();
	
	if(pid == -1)
	{
		perror("fork ");
		return -1;
	}
	
	if(pid == 0)
	{
		printf("子进程ID:%d\n",getpid());
	}
	else if(pid > 0)
	{
		printf("父进程ID:%d\n",getpid());
	}

	return 0;
}
当fork()顺利完成任务时,就会存在两个进程,每个进程都从fork()返回处开始继续

执行两个进程执行相同的代码(text)段,但是有各自的堆栈(stack)段、数据(data)段以及堆(heap)。子进程的stack、data、heap segments是从父进程拷贝过来的。fork()之后,哪一个进程先执行(scheduled to use the CPU)不确定。

二 exec函数族  

1,execl(): hello world 并不会被打印,而是执行"ls"命令

path : 被执行程序名(含完整路径)。
arg1 - argn: 被执行程序所需的命令行参数,含程序名。以空指针(NULL)结束

#include <unistd.h>
#include <sdtio.h>
//int execl(const char *path, const char *arg, ...);
//execl:创建新进程替换之前的进程
int main()
{
	int ret = execl("/bin/ls","ls",NULL);
	if(ret == -1)
	{
		perror("execl ");
		return -1;
	}
	printf("hello world \n");
	
	return 0;
}
2,execlp():

path : 被执行程序名(不含路径,将从path环境变量中查找该程序)。
arg1 - argn: 被执行程序所需的命令行参数,含程序名。以空指针(NULL)结束。

#include <unistd.h>
#include <stdio.h>

//#include <unistd.h>
 
//int execlp(const char * path, const char* arg1,...)
int main()
{
	int ret = execlp("ls","ls",NULL);
	if(ret == -1)
	{
		perror("execlp ");
		return -1;
	}
	printf("hello world \n");
	return 0;
}
3,execv():

path : 被执行程序名(含完整路径)。
argv[]: 被执行程序所需的命令行参数数组

#include <unistd.h>
#include <stdio.h>

//#include <unistd.h>

//int execv(const char *path, char *const argv[]);
int main()
{
	char *a[] = {"ls",NULL};
	int ret = execv("/bin/ls",a);
	if(ret == -1)
	{
		perror("execv ");
		return -1;
	}
	
	printf("hello world \n");
	
	return 0;
}
4,system():

调用fork产生子进程,由子进程来调用 /bin/sh -c string来执行参数string所代表的命令

#include <stdlib.h>
#include <stdio.h>

//#include <stdlib.h>

//int system(const char* string)
int main()
{
	printf("hello world \n");
	sleep(2);
	
	system("ls");//system()  不会替换之前的进程
	
	printf("hello world \n");
	
	return 0;
}

三  终止函数 

1,_exit(): 直接使进程停止,清除其使用的内存,并清除缓冲区中内容


只会打印第一个printf,第二个 printf 在缓冲区被清除了

#include <unistd.h>
#include <stdio.h>

//表头文件: #include<unistd.h>

//定义函数: void _exit(int status);

int main()
{
	printf("CSDN CSDN\n");
	
	printf("NDSC  NDSC");
	
	_exit(0);
	
	return 0;
}

2,exit(): 在停止进程之前,要检查文件的打开情况,并把文件缓冲区中的内容写回文件才停止进程

exit()用来正常终结目前进程的执行,并把参数status返回给父进程,而进程所有的缓冲区数据会自动写回并关闭未关闭的文件

两个 printf 都会打印

#include <stdlib.h>
#include <stdio.h>

//表头文件: #include <stdlib.h>

//定义函数: void _exit(int status);

int main()
{
	printf("CSDN CSDN\n");
	
	printf("NDSC  NDSC");
	
	exit(0);
	
	return 0;
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值