引入了reactivity和 WebAssembly 支持。
https://saru-tora.github.io/anansi/
各位 Rustaceans,我今年一直在写 Rust,很高兴分享我的第二个crate https://github.com/64bit/async-openai - OpenAI API 的 Rust 绑定。我的第一个crate是大约 10 个月前,我在 Rust 的旅程中已经走了很远。 它是一个新项目,因此可能存在粗糙的边缘并且尚未实现所有 API。
有趣的部分是:存储库的徽标是由 OpenAI 生成的 - 我已将该示例包含在示例目录中。
出于好奇,我正在查看本周发布在这里的一个库的源代码,我注意到短字符串被转换为u64,如下所示
let mut key: u64 = 0;let mut shift = 0;while let Some(&ch) = self.next() {match ch {b'a'..=b'z' if shift < 64 => {key |= (ch as u64) << shift;shift += 8;}b' ' | b'\t' | b'\r' | b'\n' => (),b'=' => {return key.into();}b'A'..=b'Z' if shift < 64 => {key |= ((ch - b'A' + b'a') as u64) << shift;shift += 8;}b';' => {key = 0;}_ => {key = u64::MAX;shift = 64;}}}
然后作为整数进行比较:
pub(crate) const A: u64 = b'a' as u64;
pub(crate) const B: u64 = b'b' as u64;
pub(crate) const BH: u64 = (b'b' as u64) | ((b'h' as u64) << 8);match key {A => {// do something for A}B => {// do something for B}BH => {// do something for BH}_ => {}}
我不太了解编译器内部原理,但是你们认为这样做比简单地将字节存储在[u8;8]数组中,然后将值作为字节进行比较?
From 日报小组 时光
社区学习交流平台订阅:
Rustcc 论坛:支持 rss
微信公众号:Rust语言中文社区