measuring time of a profiled “Sleep” function

后端 未结 2 457
囚心锁ツ
囚心锁ツ 2021-01-25 17:37

A few days ago I posted this question: measuring time of a profiled function

(I hope it\'s ok i\'m opening a new thread, I just can\'t find the old one in the few first

2条回答
  •  无人及你
    2021-01-25 18:38

    sleep methods almost never actually perform the "spin" mechanic you're describing- there's no reason to waste so much CPU time when all it really needs to do is set a timer inside the OS, and then simply stop running until reawakened by the timer. If a process that is already frozen due to a sleep call is frozen again because you suspended it, then it's simply suspended twice; the "alarm clock" calls back and releases its suspension, but the application is still suspended because you suspended it. If you unsuspend it before the sleep wears off, your suspend/unsuspend will have simply had no effect.

    As such, it is simply impossible for a thread to know or care about why a sleep took a different time from what was expected. It simply was not running code while it was sleeping. It stopped running code, and then it started running code again some time later, and checking the wall clock will simply tell it how long it was out, not what caused it to be frozen during that time. (Maybe it was low priority, and the OS was very busy, and it simply took that long to schedule it to run again after the sleep ended.)

    The closest you can do is to write your own sleep method and use it only for debugging purposes. (It should probably call into the system sleep method when not in debugging mode, so you don't have to change the code outside the function- use conditional compilation via #ifdef DEBUG/#endif.) That sleep should do exactly what you suggest: count ticks until the "wall clock" says it's waited long enough, and if there's an unexpectedly large gap between ticks, push the deadline out further because that time didn't "count".


    All that said:

    Maybe you've asked the wrong question here. Why are you trying to profile sleep anyway, and make it stable across manually stopping the program? Accurate profiling generally goes out the window anyway once you're freezing the program externally- it throws off almost all the timing-related properties of the program, especially with regard to CPU memory cache behavior.

提交回复
热议问题