在创建或销毁进程时,在创建或销毁进程时,系统开销
程序和工艺程序是指令和数据的集合,反映在静态的可执行文件和相关的配置文件中。
操作系统可以运行多个程序。其实CPU运行速度很快,要运行的程序很多。所以,为了让操作系统运行多个程序,CPU会将其执行时间分成很多段,比如每段0.1秒。然后,A程序运行0.1秒,然后B程序运行0.1秒,然后C程序运行0.2秒。因为这个切换非常快,所以我们感觉程序是同时运行的。
从操作系统的角度来看,运行一个程序是指一个进程。因为有切换,进程管理了很多资源,比如:打开的文件、挂起的信号、进程状态、内存地址空间等。也就是说,进程参与CPU调度,管理所有资源。
更确切地说,现代计算机的CPU运行速度非常快。当使用一个进程参与调度时,频繁地从CPU的寄存器和进程堆栈中保存运行状态和相应的信息是非常耗时的。所以现代CPU只是把进程当做一个资源管理的东西,引入线程作为CPU调用的基本单位。多个线程可以共享同一个进程的所有资源。
请注意,程序不是进程。实际上,两个或多个进程不仅可以执行同一个程序,还可以共享地址空间等资源。
Linux内核通过一个叫做进程描述符的task_struct结构来管理进程,这个结构包含了一个进程需要的所有信息。它在/include/linux/sched.h中定义。
创建流程分叉()
#包括unistd.h
#包含stdio.h
int main()
{
pid _ t fpid//fpid接收fork函数返回的值。
int count=0;
fpid=fork();
if (fpid 0)
printf( fork中的错误!);
else if (fpid==0) {
printf(我是子进程,我的进程id是%d\n ,getpid());
printf(我是孩子\ n );
计数=2;
}
否则{
printf(我是父进程,我的进程id是%d/n ,getpid());
printf(‘我是家长。\ n’);
数数;
}
Printf(统计结果为:%d\n ,count);
返回0;
}
描述:
调用fork时,将创建一个子流程,父流程和子流程都将从fork执行。fork函数有两个返回值,父进程会返回子进程的pid 0,子进程pid=0。
传统的linux操作系统统一对待所有进程,子进程复制父进程拥有的所有资源。这种方法使得创建过程非常慢,因为子进程需要复制父进程的所有地址空间。
现代操作系统主要通过以下三种方式处理:
写入时复制(需要不同的值)。轻量级进程允许父子进程共享每个进程内核中的许多数据结构,比如地址空间、文件表打开和信号处理。vfork系统调用创建的进程可以共享其父进程的内存地址空间。以防止父进程重写子进程所需的数据,并阻止父进程的执行,直到子进程退出。销毁进程出口()
#包含sys/types.h
#包含sys/wait.h
#包括unistd.h
#包含stdio.h
#包含stdlib.h
int main()
{
pid _ t fpid//fpid接收fork函数返回的值。
int count=0;
int status=0;
fpid=fork();
if (fpid 0)
printf( fork中的错误!\ n’);
else if (fpid==0) {
printf(我是子进程,我的进程id是%d\n ,getpid());
printf(我是孩子\ n );
计数=2;
退出(-10);
}
否则{
printf(我是父进程,我的进程id是%d\n ,getpid());
printf(‘我是家长。\ n’);
数数;
}
Printf(统计结果为:%d\n ,count);
//父进程捕获子进程的状态
等待(状态);
printf(parent: status: %d\n ,WEXITSTATUS(status));
返回0;
}
原创作品来自博客半条命瓜的博客,
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。