程序的顺序执行和并发执行
顺序执行:按照顺序进行执行。
- 顺序性:严格按照顺序执行,前一个结束后一个才能执行
- 封闭性:程序运行时独占资源,只有程序本身才能改变机器各种资源的状态。
- 可再现性:结果与执行速度无关,只与初始条件有关。给定相同的输入,输出结果一定相同。
顺序执行给程序员检测和纠正错误带来便利。
并发执行:多道程序系统执行环境的变化可以引起多道程序的并发执行。一组在逻辑上相互独立的程序或程序段在执行过程中其执行时间在客观上相互重叠,即一个程序尚未结束、另一个程序的执行已经开始的执行方式。
链接:多道程序系统的具体概念
- 间断性:共享资源的使用使得在并发程序之间有相互制约。相互制约导致并发程序具有:执行-暂停-执行 这种间断性的活动规律。
- 失去封闭性:多个程序共享资源,执行时必定会受到其他程序的影响。
- 不可再现性:失去封闭性,也同时失去了不可再现性。资源的利用状况和环境有关,不能保证每次同一个输入有着相同的输出。
进程的概念
程序的概念:源代码是静态文本,通过编译软件对源代码进行编译之后得到程序。
进程的定义:程序是静态的,程序每一次执行的动态过程都不一样。只用程序这一概念,只能对并发程序进行静止的、孤立的