标准库宏扩展
大约 2 分钟std-macro-extensionsstdmacrorust
目录
说明
提示
这是一个为 Rust 标准库数据结构提供的宏扩展集合,简化了常见集合(如 HashMap
、Vec
等)的创建和操作。
特性
- 简化初始化:使用宏轻松创建常见数据结构的实例。
- 支持多种数据结构:包括
Vec
、HashMap
、Arc
等的宏。 - 易于使用:直观的语法使数据结构的创建更加迅速。
安装
要安装 std-macro-extensions
,请运行以下命令:
cargo add std-macro-extensions
用法
以下是如何使用该 crate 提供的宏的一些示例:
示例:使用 arc!
use std_macro_extensions::*;
fn main() {
let value = arc!(5);
}
示例:使用 b_tree_map!
use std_macro_extensions::*;
fn main() {
let empty_map: BTreeMap<i32, i32> = b_tree_map!();
let b_tree_map_a: BTreeMap<&str, &str> = b_tree_map!(
"a" => "a",
"b" => "b"
);
}
示例:使用 b_tree_map!
use std_macro_extensions::*;
fn main() {
let empty_set: BTreeSet<i32> = b_tree_set!();
let number_set: BTreeSet<i32> = b_tree_set!(1, 2, 3);
}
示例:使用 boxed!
use std_macro_extensions::*;
fn main() {
let boxed_value = boxed!(10);
}
示例:使用 cell!
use std_macro_extensions::*;
fn main() {
let cell_value: Cell<i32> = cell!(5);
}
示例:使用 hash_map!
use std_macro_extensions::*;
fn main() {
let my_map: HashMap<&str, i32> = hash_map!();
let my_map: HashMap<&str, i32> = hash_map!("a" => 1, "b" => 2);
}
示例:使用 hash_set!
use std_macro_extensions::*;
fn main() {
let my_set: HashSet<i32> = hash_set!();
let my_set: HashSet<i32> = hash_set!(1, 2, 3);
}
示例:使用 linked_list!
use std_macro_extensions::*;
fn main() {
let my_list: LinkedList<i32> = linked_list!();
let my_list: LinkedList<i32> = linked_list!(1, 2, 3);
}
示例:使用 mutex!
use std_macro_extensions::*;
fn main() {
let my_mutex: Mutex<i32> = mutex!(5);
let lock: MutexGuard<'_, i32> = my_mutex.lock().unwrap();
}
示例:使用 rc!
use std_macro_extensions::*;
fn main() {
let my_rc = rc!(5);
}
示例:使用 refcell!
use std_macro_extensions::*;
fn main() {
let my_refcell = refcell!(5);
}
示例:使用 rw_lock!
use std_macro_extensions::*;
fn main() {
let my_rwlock = rw_lock!(5);
}
示例:使用 string!
use std_macro_extensions::*;
fn main() {
let empty_string = string!();
let hello_string = string!("Hello");
}
示例:使用 vector!
use std_macro_extensions::*;
fn main() {
let empty_vector: Vec<i32> = vector!();
let numbers = vector!(1, 2, 3);
}
示例:使用 vector_deque!
use std_macro_extensions::*;
fn main() {
let empty_deque: VecDeque<i32> = vector_deque!();
let numbers = vector_deque!(1, 2, 3);
}
示例:使用 join_paths!
let combined_path: String = join_paths!("/home/", "/user/", "/documents", "file.txt");
let another_path: String = join_paths!("C:/", "/Program Files", "App");
可用的宏
arc!
:创建一个Arc<T>
。vector!
:创建一个Vec<T>
。map!
:创建一个HashMap<K, V>
。set!
:创建一个HashSet<T>
。b_tree_map!
:创建一个BTreeMap<K, V>
。b_tree_set!
:创建一个BTreeSet<T>
。list!
:创建一个LinkedList<T>
。heap!
:创建一个BinaryHeap<T>
。string!
:创建一个String
。boxed!
:创建一个Box<T>
。rc!
:创建一个Rc<T>
。arc!
:创建一个Arc<T>
。mutex!
:创建一个Mutex<T>
。rw_lock!
:创建一个RwLock<T>
。cell!
:创建一个Cell<T>
。ref_cell!
:创建一个RefCell<T>
。vector_deque!
: Creates aVecDeque<T>
。join_paths!
: 将多个路径组合成一个有效的路径,并处理重叠的斜杠。
许可证
本项目根据 MIT 许可证授权。有关详细信息,请参见 license 文件。
贡献
欢迎贡献!请打开一个问题或提交拉取请求。
联系方式
如有任何询问,请联系作者 ltpp-universe root@ltpp.vip。