Multithreading, when to yield versus sleep

≡放荡痞女 提交于 2019-12-31 09:04:48

问题


To clarify terminology, yield is when thread gives up its time slice. My platform of interest is POSIX threads, but I think the question is general.

Suppose I have consumer/producer pattern. If I want to throttle either consumer or producer, which is better to use, sleep or yield? I am mostly interested in efficiency of using either function.


回答1:


The "right" way to code a producer / consumer is to have the consumer wait for the producer's data. You can achieve this by using a synchronization object such as a Mutex. The consumer will Wait on the mutex, which blocks it from executing until data is available. In turn, the producer will signal the mutex when data is available, which will wake up the consumer thread so it can begin processing. This is more efficient than sleep in terms of both:

  • CPU utilization (no cycles are wasted), and
  • Run Time (execution begins as soon as data is available, not when a thread is scheduled to wake up).

That said, here is an analysis of yield vs sleep that you asked for. You may need to use such a scheme if for some reason waiting for output is not feasible:

It depends how much traffic you are receiving - if data is constantly being received and processed, you might consider doing a yield. However in most cases this will result in a "busy" loop that spends most of its time needlessly waking up the thread to check if anything is ready.

You will probably want to either sleep for a short period of time (perhaps for less than a second, using usleep) OR even better use a synchronization object such as a mutex to signal that data is available.




回答2:


sleep and yield are not the same. When calling sleep the process/thread gives CPU to another process/thread for the given amount of time.

yield relinquishes the CPU to another thread, but may return immediately if there are no other threads that waits for CPU.

So if you want to throttle, for example when streaming data at regular intervals, then sleep or nanosleep are the functions to use.

If synchronization between producer/consumer is needed, you should use a mutex/conditional wait.




回答3:


One good reason to sleep instead of yield is when there is too much contention at a specific critical section. Lets say for example you try to acquire two locks and there is a lot of contention on both locks. Here you can use sleep to employ an exponential back off. This would allow each failed attempt to pseudo randomly back off to allow other thread to succeed.

Yielding in this situation doesn't really help as much because the prospect of a random back off can increase likelihood that thread starvation would not occur.

Edit: Though I know this isn't necessarily java specific. Java's implementation of Thread.sleep(0) has the same effect of Thread.yield() At that point its more of a matter of style.




回答4:


In java, some JVM implementations treat Thread.yield() as no-op, meaning it may have no effect. Calling Thread.sleep() does not necessarily mean that scheduler should yield the CPU to another thread; this is implementation dependent too. It may context-switch to another thread that is waiting or it may not in order to amortize the cost associated with context-switch.



来源:https://stackoverflow.com/questions/2668546/multithreading-when-to-yield-versus-sleep

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!