程序并发执行与顺序执行相比会产生可分割性、失去封闭性、失去可再现性。
可分割性:通过并发执行有可能提高计算的性能。有些程序本质上并不需要并行执行,但如果能使用多个处理器同时计算,可能得到很大的速度提升,或者满足实际的需要。
失去可再现性:计算机硬件通常控制着一批独立设备和部件。这些设备/部件的特性和 *** 作速度不同,相应控制程序最好作为独立的进程,根据需要开始/结束或暂时中断。需要与处理器上运行的其他线程交互,实现系统的整体行为。
失去封闭性:许多程序里,特别是各种服务器、图形应用、计算机模拟等,需要做很多基本上相互独立的工作。构造这种程序,最简单也最合逻辑的方式,就是用一个独立的执行进程实现一个工作。
扩展资料:
程序并发执行的主要特点是并发程序间具有相互制约的关系,程序并发执行失去了程序的封闭性和再现性,程序和机器执行程序的活动不再一一对应。
从程序的活动方面看,则可能有若干个作业程序同时或者相互穿插在系统中并发执行。这时,计算机不再是简单的顺序执行一道程序。也就是说,一道程序的前一 *** 作结束后,系统不一定立即执行其后续的 *** 作,而可能转而执行其他程序的某一 *** 作。
通常在多道程序工作环境中。程序的并发执行在两个线程运行的时候,会首先将r这个值读取到线程的本地缓存(这里指的并不是Thread Local)中,在线程运行中,线程不会每次都去到主存中读取r值,而是会一直读取本地缓存中的r,那么在睡眠1s后,主线程将它本地缓存中r的值更改为false,但是即便是同步到了主存中,thread1还是不会去主存中读取更新之后的r,这就导致了程序无法结束。而线程间的可见性指的就是:多个线程去访问同一块内存,当其中的一个线程对内存中的数据进行了修改之后,另一个线程是否能立即可见
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)