1个不稳定版本
0.1.0 | 2020年2月3日 |
---|
#35 in #communicating
9KB
97 行
proc-graph
概述
一个小型库,可以将进程图转换为通信进程集。
入门指南
# Cargo.toml
[dependencies]
proc-graph = "0.1"
用法
use std::{thread, time::Duration};
use proc_graph::Network;
fn main() {
env_logger::init();
let mut net = Network::new();
net.add_process("a", vec!["b", "c"], |senders, _| loop {
thread::sleep(Duration::from_secs(1));
for (adj, s) in senders.iter() {
println!("a is sending to {}", adj);
s.send(("a".to_string(), ()))
.expect("shouldn't encounter a closed channel");
}
});
net.add_process("b", vec!["d"], |senders, receiver| loop {
thread::sleep(Duration::from_secs(1));
let (sender, _) = receiver
.recv()
.expect("shouldn't encounter a closed channel");
println!("b received from {}", sender);
for s in senders.values() {
s.send(("b".to_string(), ()))
.expect("shouldn't encounter a closed channel");
}
});
net.add_process("c", vec!["d"], |senders, receiver| loop {
thread::sleep(Duration::from_secs(1));
let (sender, _) = receiver
.recv()
.expect("shouldn't encounter a closed channel");
println!("c received from {}", sender);
for s in senders.values() {
s.send(("c".to_string(), ()))
.expect("shouldn't encounter a closed channel");
}
});
net.add_process("d", vec![], |_, receiver| loop {
thread::sleep(Duration::from_secs(1));
let (sender, _) = receiver
.recv()
.expect("shouldn't encounter a closed channel");
println!("d received from {}", sender);
});
net.start();
}
许可证
proc-graph
使用MIT许可证(MIT)许可,除非另有说明。请参阅LICENSE 了解更多详细信息。
依赖项
~2–11MB
~98K SLoC