getrusage()如何报告hibernate时间?
我目前正在使用getrusage
告诉我在应用程序的事件循环中花了多少时间。
我想知道这会如何受到冬眠的影响。 是否报告了hibernate时间? 或者也许是系统时间? 这是在Posix的某处指定的还是这个系统依赖的?
编辑在这里向Windows提出同样的问题。
我不认为POSIX在任何地方提到hibernate,所以它在技术上依赖于平台。
我只能说Linux,但其他UNIX变种 – 甚至可能是Windows – 可能表现得相似,因为这是最有意义的。
在Linux中,内核源代码下的Documentation / power / swsusp.txt中描述了在hibernate状态下发生的事情的具体细节。 简而言之,用户进程发送一个伪信号,导致它们切换到TASK_UNINTERRUPTIBLE
状态。 TASK_UNINTERRUPTIBLE
状态中的进程从运行队列中取出并进入hibernate状态,直到它等待的条件成为现实,因此在TASK_UNINTERRUPTIBLE
花费的时间既不算作用户时间也不算作系统时间。 如果您要测量运行time(1)
,您最多会看到它有助于挂钟时间。
使用getrusage(2)
,您将看不到任何报告的CPU时间的差异,因为该进程不可运行。
所以,回答你的问题:根本没有报告hibernate时间。