进程创建和运行

作者: greedyhao | 来源:发表于2017-08-21 11:17 被阅读0次

欢迎关注我的博客Zhuhao's Blog获取最新文章

简单的说,每个应用在运行时就会产生一个进程,这个进程就对这个应用负责,掌握这个应用的运行状态。

可是为什么还要用一个进程来控制一个应用呢,下面将会简单的解释一下。

现在的应用对于资源的要求都是狮子大开口,开口就是几个G,一台电脑的内存一般也就几个G,总不能一台电脑就跑这一个应用吧。为了解决这个问题,操作系统就使用了虚拟内存,让每个进程代表一个应用,给每个进程一种自己独霸整台电脑的假象,然后操作系统进行上下文切换,只把这个进程正好需要使用的资源放进内存;这样每个进程都有自己独有的资源。

创建进程

创建进程需要一个系统调用 fork(),fork可以创建一个和当前进程映像一样的进程;成功时创建子进程并返回子进程的pid,失败时不会创建子进程,返回-1并设置相应的errno。

顺便介绍一下pid,pid是进程的ID,数据类型是pid_t,在Linux中被定义为int。可以调用 getpid()来获得调用进程的pid,还可以通过调用 getppid() 来获得调用进程的父进程的pid。

运行进程

运行进程需要调用 exec 系统调用,但是不存在单一的exec函数,他是由一系列的exec函数组成的。

以一个最简单的调用 execl() 为例:

  • 成功的execl()调用改变 地址空间 和进程映像
  • 所有的挂起的信号都会丢失
  • 捕捉到的所有信号都会还原为默认处理方式
  • 丢弃所有的内存锁
  • 大多数进程的属性会还原成默认值(pid 父进程的pid 优先级 所属的用户和组 不会变)
  • 清空和进程内存地址空间相关的所有数据,包括所有映射的文件

终止进程

终止进程使用的是 exit() 系统调用,参数用于表示进程的推出状态, EXIT_SUCCESSEXIT_FAILURE 这两个可移植的宏分别表示成功和失败(也可以使用0和非0值来表示,不过可移植性就差了)。

简单的表示成功退出就使用

exit(EXIT_SUCCESS);

这个系统调用会先完成在用户空间需要做的事,再调用_exit()再处理内核中的事。

在用户空间做的事

  • 调用任何由 atexit()on_exit() 注册的函数,按在系统中注册的相反顺序。(假如在exit()前运行了atexit(a) atexit(b),那么在调用exit()后就会先运行b再运行a )
  • 清空所有已打开的标准I/O流
  • 删除有tmpfile()函数创建的所有临时文件

内核会清理进程所创建的 不再使用的所有资源这包括但不局限于:分配内存 打开文件和System Ⅴ的信号量。清理完成后,内核会摧毁进程,并告知父进程其子进程已经终止。

参考源

相关文章

  • 进程创建和运行

    欢迎关注我的博客Zhuhao's Blog获取最新文章 简单的说,每个应用在运行时就会产生一个进程,这个进程就对这...

  • 线程的创建和控制

    线程的创建和控制 进程和线程的关系:进程提供资源,线程使用资源完成工作 创建线程函数 线程的控制 更多的API 创...

  • 程序和进程的关系

    程序和进程的关系 程序就是静态的代码和数据 而进程就是程序的一次运行过程 进程有自己的生命周期,随着任务的启动而创...

  • Kubernetes——Pod详解

    Pod介绍 Pod是kubernetes中可以创建和部署的最小也是最简的单位。一个Pod代表着集群中运行的一个进程...

  • 进程管理

    进程(process)通常可被归为父进程和子进程。 父进程负责创建和结束子进程。子进程调用exit()并不能立即结...

  • Binder源码阅读(java层)

    宏观上Binder机制 Binder机制小案例(进程通信) 进程A 进程B 创建和进程A一模一样的aidl文件,包...

  • 3、并发编程-Java线程

    并发编程 Java线程 创建和运行线程 查看线程 线程API 线程状态 创建和运行线程 方法一,直接使用new T...

  • linux应用程序进程操作(fork vfork)

    1fork ,fork的子进程和父进程同时运行,运行顺序不确定 2 vfork先运行子进程,再运行父进程 3 fo...

  • java 线程与协程总结

    基础知识1、进程和线程 进程是资源(CPU、内存等)分配的基本单位,它是程序执行时的一个实例。程序运行时系统就会创...

  • 学习笔记-locust运行模式

    1、locust运行方式 运行Locust时,通常会使用到两种运行模式:单进程运行和多进程分布式运行。 2、单进程...

网友评论

    本文标题:进程创建和运行

    本文链接:https://www.haomeiwen.com/subject/jdjcdxtx.html