47 lines
1.1 KiB
Rust
47 lines
1.1 KiB
Rust
use std;
|
|
import task;
|
|
import comm;
|
|
|
|
fn main() { test00(); }
|
|
|
|
fn test00_start(c: comm::chan<int>, start: int, number_of_messages: int) {
|
|
let mut i: int = 0;
|
|
while i < number_of_messages { comm::send(c, start + i); i += 1; }
|
|
}
|
|
|
|
fn test00() {
|
|
let mut r: int = 0;
|
|
let mut sum: int = 0;
|
|
let p = comm::port();
|
|
let number_of_messages: int = 10;
|
|
let c = comm::chan(p);
|
|
|
|
do task::spawn {||
|
|
test00_start(c, number_of_messages * 0, number_of_messages);
|
|
}
|
|
do task::spawn {||
|
|
test00_start(c, number_of_messages * 1, number_of_messages);
|
|
}
|
|
do task::spawn {||
|
|
test00_start(c, number_of_messages * 2, number_of_messages);
|
|
}
|
|
do task::spawn {||
|
|
test00_start(c, number_of_messages * 3, number_of_messages);
|
|
}
|
|
|
|
let mut i: int = 0;
|
|
while i < number_of_messages {
|
|
r = comm::recv(p);
|
|
sum += r;
|
|
r = comm::recv(p);
|
|
sum += r;
|
|
r = comm::recv(p);
|
|
sum += r;
|
|
r = comm::recv(p);
|
|
sum += r;
|
|
i += 1;
|
|
}
|
|
|
|
assert (sum == number_of_messages * 4 * (number_of_messages * 4 - 1) / 2);
|
|
}
|