程序的并发执行是指

程序的并发执行是指,第1张

多个程序线程、进程等)同时执行,互不干扰,而且它们的执行顺序并没有固定的规律。在计算机领域中,并发是指在同一时间段内,有多个独立的任务被执行。并发执行可以提高程序的性能和效率,使得多个任务可以同时执行,避免了单一程序执行的瓶颈问题。

程序并发执行与顺序执行相比会产生可分割性、失去封闭性、失去可再现性。

可分割性:通过并发执行有可能提高计算的性能。有些程序本质上并不需要并行执行,但如果能使用多个处理器同时计算,可能得到很大的速度提升,或者满足实际的需要。

失去可再现性:计算机硬件通常控制着一批独立设备和部件。这些设备/部件的特性和 *** 作速度不同,相应控制程序最好作为独立的进程,根据需要开始/结束或暂时中断。需要与处理器上运行的其他线程交互,实现系统的整体行为。

失去封闭性:许多程序里,特别是各种服务器、图形应用、计算机模拟等,需要做很多基本上相互独立的工作。构造这种程序,最简单也最合逻辑的方式,就是用一个独立的执行进程实现一个工作。

扩展资料:

程序并发执行的主要特点是并发程序间具有相互制约的关系,程序并发执行失去了程序的封闭性和再现性,程序和机器执行程序的活动不再一一对应。

从程序的活动方面看,则可能有若干个作业程序同时或者相互穿插在系统中并发执行。这时,计算机不再是简单的顺序执行一道程序。也就是说,一道程序的前一 *** 作结束后,系统不一定立即执行其后续的 *** 作,而可能转而执行其他程序的某一 *** 作。

通常在多道程序工作环境中。程序的并发执行在两个线程运行的时候,会首先将r这个值读取到线程的本地缓存(这里指的并不是Thread Local)中,在线程运行中,线程不会每次都去到主存中读取r值,而是会一直读取本地缓存中的r,那么在睡眠1s后,主线程将它本地缓存中r的值更改为false,但是即便是同步到了主存中,thread1还是不会去主存中读取更新之后的r,这就导致了程序无法结束。

而线程间的可见性指的就是:多个线程去访问同一块内存,当其中的一个线程对内存中的数据进行了修改之后,另一个线程是否能立即可见


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7729774.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-09
下一篇 2023-04-09

发表评论

登录后才能评论

评论列表(0条)

保存