]> git.lizzy.rs Git - rust.git/blobdiff - doc/tutorial-tasks.md
doc: Fix deadlocks in tutorial due to yield bustage
[rust.git] / doc / tutorial-tasks.md
index b5677a261c45bffd12d1d80907e3df7ed035f45f..d9e4b9b399d2c623309e8d88cc479d867abdc11f 100644 (file)
@@ -492,7 +492,8 @@ either task fails, it kills the other one.
 
 ~~~
 # use std::task;
-# fn sleep_forever() { loop { task::yield() } }
+# use std::comm::oneshot;
+# fn sleep_forever() { loop { let (p, c) = oneshot::<()>(); p.recv(); } }
 # do task::try {
 do spawn {
     do spawn {
@@ -513,9 +514,10 @@ before returning. Hence:
 
 ~~~
 # use std::comm::{stream, Chan, Port};
+# use std::comm::oneshot;
 # use std::task::{spawn, try};
 # use std::task;
-# fn sleep_forever() { loop { task::yield() } }
+# fn sleep_forever() { loop { let (p, c) = oneshot::<()>(); p.recv(); } }
 # do task::try {
 let (receiver, sender): (Port<int>, Chan<int>) = stream();
 do spawn {  // Bidirectionally linked
@@ -543,7 +545,8 @@ an intermediate generation has already exited:
 
 ~~~
 # use std::task;
-# fn sleep_forever() { loop { task::yield() } }
+# use std::comm::oneshot;
+# fn sleep_forever() { loop { let (p, c) = oneshot::<()>(); p.recv(); } }
 # fn wait_for_a_while() { for _ in range(0, 1000u) { task::yield() } }
 # do task::try::<int> {
 do task::spawn_supervised {