Rust 以其安全性为重点,为不同的类型之间的转换提供了不同的方法。首先,as 用于数据类型安全转换 。相反,transmute 允许类型之间的任意转换,是 Rust 的最危险的特征!asas 关键字可以做基本的转换:let x: i32 = 5;let y = x as i64;然而,它只允许某些类型的转换:let a = [0u8, 0u8, 0u8, 0u8];let b = a as u32;
你可以使用 type 关键字声明另一类型的别名:type Name = String;然后,你可以就像使用一个真正的类型一样使用这种类型:type Name = String;let x: Name = "Hello".to_string();但是请注意,这是一个别名,不完全是一个新类型。换句话说,因为 Rust 是强类型的,所以你不能比较两个不同类型:let x: i32 = 5;let y: i64 = 5;if x == y { // ...
有时,函数可以有相同的名字。看看下面这段代码:trait Foo {fn f(&self);}trait Bar {fn f(&self);}struct Baz;impl Foo for Baz {fn f(&self) { println!("Baz’s impl of Foo"); }}impl Bar for Baz {fn f(&self) { println!("Baz’s impl of Bar"); }}let b = Baz;如果我们试图调用 b.
If let 允许你把 if 和 let 结合到一起,来减少某些类型的模式匹配所需的开销。例如,有某种 Option<T>。如果它是 Some<T>,我们希望在它上面调用一个函数,如果不是,则什么也不做。就像下面这样:match option {Some(x) => { foo(x) },None => {},}在这里我们不一定非要使用匹配,例如,我们可以使用 ifif option.is_some() {let x = option.
对于任何程序员来说,字符串是一个重要的且必须掌握的概念。由于其系统专注的点不同,Rust 的字符串处理系统有点不同于其他计算机语言,。无论何时,当你有一个可变大小的数据结构,事情可能会变得棘手,还有,字符串是一种能重设大小的数据结构。也就是说,Rust 的字符串的工作方式也不同于其他的系统语言,如 C 语言。让我们深入细节。
函数很好,但是如果你想要在一些数据上调用很多函数,那是非常不合适的。请思考以下代码: baz(bar(foo)));我们从左往右读这些代码,就会看到 ‘baz bar foo’。但是这并不是我们由内-外调用函数的顺序:‘foo bar baz’。如果我们这样写,会不会更好? foo.bar().baz();幸运的是,你可能已经猜到了,关于上面问题的答案,可以!