使用while()和sleep()将程序置于睡眠模式之间的区别
我创建了一个共享对象,并从两个不同的程序访问它并测量时间。
DATA数组是两个进程之间的共享对象。
案例1:在program1中使用while
program1:
access shared DATA array ;// to load into memory and avoid page fault during access time calculation start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program1, Time1=%d\n",Time_needed); start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program1, Time2=%d\n",Time_needed); while(1){}; // I replace this by sleep(1000) in CASE-2
计划2:
access shared DATA array ;// to load into memory and avoid page fault during access time calculation start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program2, Time1=%d\n",Time_needed); start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program2, Time1=%d\n",Time_needed);
输出:首先我运行program1,然后运行Program2
Inside Program1, Time1 = 17620 Inside Program1, Time1 = 17680 Inside Program2, Time1 = 7620 Inside Program2, Time1 = 7600
案例2:在program1中使用sleep()
program1:
access shared DATA array ;// to load into memory and avoid page fault during access time calculation start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program1, Time1=%d\n",Time_needed); start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program1, Time2=%d\n",Time_needed); sleep(1000);
计划2:
access shared DATA array ;// to load into memory and avoid page fault during access time calculation start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program2, Time1=%d\n",Time_needed); start=timer; access shared DATA array end=timer; Time_needed= end-start printf("Inside Program2, Time1=%d\n",Time_needed);
输出:首先我运行program1,然后运行Program2
Inside Program1, Time1 = 17620 Inside Program1, Time1 = 17680 Inside Program2, Time1 = 17620 Inside Program2, Time1 = 17600
从情况-1的输出,我可以说共享数据DATA数组由第一个程序加载到内存/缓存中,第二个程序从缓存中访问它。 虽然对于CASE-2也是如此,但结果看起来在Program1进入hibernate状态时从缓存中刷新。
我在linux下使用GCC。
任何线索? 提前致谢 。
你没有准确描述你如何运行不同的版本(不同的进程?),但假设它们是顺序的 – 你可能会看到睡眠的影响()
它当然取决于确切的实现和硬件,但它很可能会让你的CPU进入一些节能/睡眠状态(这就是它的设计目的)。 如果是这种情况,那么核心缓存将不得不作为流程的一部分进行刷新,并且您将使用冷缓存唤醒。 另一方面,whie循环用于在磨削CPU并使其保持活动状态(以及缓存)时执行繁忙的等待循环,除非您碰巧在此过程中进行了上下文切换。
确切的细节将再次依赖于实现,在x86上,您可以使用内联汇编来调用monitor + mwait指令,以允许您指定要实现的确切C状态深度。 它越深,越多的缓存将被关闭(主要与L3相关)。
我认为我们无法根据您的情况预测缓存行为。
它还取决于您未提及的H / W(如存在多少CPU核心(物理或逻辑))。
我们不能说program_2将被安排在同一个核心上,并且就在program_1之后,因为它完全依赖于OS调度程序。 因此program_2可以使用program_1填充的缓存。
由于在program_1之后安排的其他程序,缓存可能会被刷新。