使用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之后安排的其他程序,缓存可能会被刷新。