并发执行时,系统中的各资源将为它们所共享,而这些资源的状态也有这些程序来改变,致使其中的任意程序在运行时,其环境必然会受到其他程序的影响。
初始数据的更改也会影响结果,两个程序去改一个变量,总要乱的~
程序并发执行与顺序执行相比会产生可分割性、失去封闭性、失去可再现性。
可分割性:通过并发执行有可能提高计算的性能。有些程序本质上并不需要并行执行,但如果能使用多个处理器同时计算,可能得到很大的速度提升,或者满足实际的需要。
失去可再现性:计算机硬件通常控制着一批独立设备和部件。这些设备/部件的特性和 *** 作速度不同,相应控制程序最好作为独立的进程,根据需要开始/结束或暂时中断。需要与处理器上运行的其他线程交互,实现系统的整体行为。
失去封闭性:许多程序里,特别是各种服务器、图形应用、计算机模拟等,需要做很多基本上相互独立的工作。构造这种程序,最简单也最合逻辑的方式,就是用一个独立的执行进程实现一个工作。
扩展资料:
程序并发执行的主要特点是并发程序间具有相互制约的关系,程序并发执行失去了程序的封闭性和再现性,程序和机器执行程序的活动不再一一对应。
从程序的活动方面看,则可能有若干个作业程序同时或者相互穿插在系统中并发执行。这时,计算机不再是简单的顺序执行一道程序。也就是说,一道程序的前一 *** 作结束后,系统不一定立即执行其后续的 *** 作,而可能转而执行其他程序的某一 *** 作。
与电脑的单核和多核类似,顺序执行没个时间段只能执行一个任务,一个线程执行中,其他线程必须等待该线程执行完才能执行,如果是并发执行,每个时间段并发地执行多个任务,一般没有先后顺序区分,这样大大提高程序的整体执行效率。
因为程序在并发执行时,是多个程序共享系统中的各种资源,就像一扇门没上锁,很多人都进进出出一样,程序的运行,它用到的资源的状态可以被其他程序随意改变,程序也自然就失去了封闭性;由于失去了封闭性,程序经过多次执行后,其计算机结果已与并发程序的执行速度有关,从而使程序的执行失去了可再现性。例如:
有两个循环程序A和B,它们共享一个变量N。程序A每执行一次时,都要做N∶=N+1 *** 作;程序B每执行一次时, 都要执行Print(N) *** 作,然后再将N置成“0”。程序A和B以不同的速度运行。
(1) N∶=N+1在Print(N)和N∶=0之前,此时得到的N值分别为N +1, N +1, 0。
(2) N∶=N+1在Print(N)和N∶=0之后,此时得到的N值分别为 N, 0, 1。
(3) N∶=N+1在Print(N)和N∶=0之间,此时得到的N值分别为N, N +1, 0。
换句话说,就是程序经过多次执行后,虽然它们执行时的环境与初始条件相同,但得到的结果却各不相同。希望能帮到你。
以上就是关于程序并发执行时失去程序的封闭性的主要原因全部的内容,包括:程序并发执行时失去程序的封闭性的主要原因、程序并发执行与顺序执行相比会产生哪些新特征、程序顺序执行与并发执行有什么不同等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)