這是 amethyst 項目下的底層網絡庫,能夠獨立使用。提供了可靠傳輸與不可靠傳輸的選擇。編程
發包微信
use laminar::{Socket, Packet};
// create the socketlet (mut socket, packet_sender, _) = Socket::bind("127.0.0.1:12345")?;
// our datalet bytes = vec![...];
// You can create packets with different reliabilitieslet unreliable = Packet::unreliable(destination, bytes);let reliable = Packet::reliable_unordered(destination, bytes);
// We can specify on which stream and how to order our packets, checkout our book and documentation for more informationlet unreliable = Packet::unreliable_sequenced(destination, bytes, Some(1));let reliable_sequenced = Packet::reliable_sequenced(destination, bytes, Some(2));let reliable_ordered = Packet::reliable_ordered(destination, bytes, Some(3));
// send the created packetspacket_sender.send(unreliable_sequenced).unwrap();packet_sender.send(reliable).unwrap();packet_sender.send(unreliable_sequenced).unwrap();packet_sender.send(reliable_sequenced).unwrap();packet_sender.send(reliable_ordered).unwrap();
收包
網絡
use laminar::{SocketEvent, Socket};
// create the socketlet (mut socket, _, packet_receiver) = Socket::bind("127.0.0.1:12346")?;
// wait until a socket event occurslet result = packet_receiver.recv();
match result { Ok(socket_event) => { match socket_event { SocketEvent::Packet(packet) => { let endpoint: SocketAddr = packet.addr(); let received_data: &[u8] = packet.payload(); }, SocketEvent::Connect(connect_event) => { /* a client connected */ }, SocketEvent::Timeout(timeout_event) => { /* a client timed out */}, } } Err(e) => { println!("Something went wrong when receiving, error: {:?}", e); }}
Read More
Repo
閉包
cp 的替代品啊。什麼都不說了,炫酷上圖吧app
Repo機器學習
此庫爲 ndarray 的 ArrayBase
類型提供了統計方法。socket
到目前爲止,Scipy.stats (Python)
和 StatsBase.jl (Julia)
中的大部分統計特性都已經移植過來了。用 Rust 作機器學習的同窗是否是能夠上手了?ide
Repo工具
本庫做者還邀請你們一塊兒來討論這個庫的將來走向,好機會。學習
Roadmap
Rust官方及社區最新信息蒐集、文章推送,教程學習,技巧分享,社區交流。信息來源是整個全球Rust社區。
之後本日報也會同步更新到此公衆賬號去。
讀者frostRed和Yim前後總結出來的規則,你們能夠參考討論。
Github
在隨書源碼選擇「精選」label也可看到。
這篇文章 詳細說明了要達到這個目標須要注意的點,和相關的可以使用的輔助工具。