You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

8.7 KiB

附录 B运算符与符号

该附录包含了 Rust 目前出现过的各种符号,这些符号之前都分散在各个章节中。

运算符

表 B-1 包含了 Rust 中的运算符、上下文中的示例、简短解释以及该运算符是否可重载。如果一个运算符是可重载的,则该运算符上用于重载的特征也会列出。

下表中,expr是表达式,ident是标识符,type是类型,var是变量,trait是特征,pat是匹配分支(pattern)。

表 B-1: 运算符

运算符 示例 解释 是否可重载
! ident!(...), ident!{...}, ident![...] 宏展开
! !expr 按位非或逻辑非 Not
!= var != expr 不等比较 PartialEq
% expr % expr 算术求余 Rem
%= var %= expr 算术求余与赋值 RemAssign
& &expr, &mut expr 借用
& &type, &mut type, &'a type, &'a mut type 借用指针类型
& expr & expr 按位与 BitAnd
&= var &= expr 按位与及赋值 BitAndAssign
&& expr && expr 逻辑与
* expr * expr 算术乘法 Mul
*= var *= expr 算术乘法与赋值 MulAssign
* *expr 解引用
* *const type, *mut type 原生指针
+ trait + trait, 'a + trait 复合类型限制
+ expr + expr 算术加法 Add
+= var += expr 算术加法与赋值 AddAssign
, expr, expr 参数以及元素分隔符
- - expr 算术取负 Neg
- expr - expr 算术减法 Sub
-= var -= expr 算术减法与赋值 SubAssign
-> fn(...) -> type, |...| -> type 函数与闭包,返回类型
. expr.ident 成员访问
.. .., expr.., ..expr, expr..expr 右半开区间 PartialOrd
..= .., expr.., ..expr, expr..expr 闭合区间 PartialOrd
.. ..expr 结构体更新语法
.. variant(x, ..), struct_type { x, .. } “代表剩余部分”的模式绑定
... expr...expr (不推荐使用,用..=替代) 闭合区间
/ expr / expr 算术除法 Div
/= var /= expr 算术除法与赋值 DivAssign
: pat: type, ident: type 约束
: ident: expr 结构体字段初始化
: 'a: loop {...} 循环标志
; expr; 语句和语句结束符
; [...; len] 固定大小数组语法的部分
<< expr << expr 左移 Shl
<<= var <<= expr 左移与赋值 ShlAssign
< expr < expr 小于比较 PartialOrd
<= expr <= expr 小于等于比较 PartialOrd
= var = expr, ident = type 赋值/等值
== expr == expr 等于比较 PartialEq
=> pat => expr 匹配分支语法的部分
> expr > expr 大于比较 PartialOrd
>= expr >= expr 大于等于比较 PartialOrd
>> expr >> expr 右移 Shr
>>= var >>= expr 右移与赋值 ShrAssign
@ ident @ pat 模式绑定
^ expr ^ expr 按位异或 BitXor
^= var ^= expr 按位异或与赋值 BitXorAssign
| pat | pat 模式匹配中的多个可选条件
| expr | expr 按位或 BitOr
|= var |= expr 按位或与赋值 BitOrAssign
|| expr || expr 逻辑或
? expr? 错误传播

非运算符符号

表 B-2独立语法

符号 解释
'ident 生命周期名称或循环标签
...u8, ...i32, ...f64, ...usize, 等 指定类型的数值常量
"..." 字符串常量
r"...", r#"..."#, r##"..."##, etc. 原生字符串, 未转义字符
b"..." &str 转换成 &[u8; N] 类型的数组
br"...", br#"..."#, br##"..."##, 等 原生字节字符串,原生和字节字符串字面值的结合
'...' Char字符
b'...' ASCII字节
|...| expr 闭包
! 代表总是空的类型,用于发散函数(无返回值函数)
_ 模式绑定中表示忽略的意思;也用于增强整型字面值的可读性

表 B-3展示了模块和对象调用路径的语法。

表 B-3路径相关语法

符号 解释
ident::ident 命名空间路径
::path 从当前的包的根路径开始的相对路径
self::path 与当前模块相对的路径(如一个显式相对路径)
super::path 与父模块相对的路径
type::ident, <type as trait>::ident 关联常量、关联函数、关联类型
<type>::... 不可以被直接命名的关联项类型(如 <&T>::...<[T]>::... 等)
trait::method(...) 使用特征名进行方法调用,以消除方法调用的二义性
type::method(...) 使用类型名进行方法调用, 以消除方法调用的二义性
<type as trait>::method(...) 将类型转换为特征,再进行方法调用,以消除方法调用的二义性

表 B-4 展示了使用泛型参数时用到的符号。

表 B-4泛型

符号 解释
path<...> 为一个类型中的泛型指定具体参数(如 Vec<u8>
path::<...>, method::<...> 为一个泛型、函数或表达式中的方法指定具体参数,通常指双冒号(turbofish)(如 "42".parse::<i32>()
fn ident<...> ... 泛型函数定义
struct ident<...> ... 泛型结构体定义
enum ident<...> ... 泛型枚举定义
impl<...> ... 实现泛型
for<...> type 高阶生命周期限制
type<ident=type> 泛型,其一个或多个相关类型必须被指定为特定类型(如 Iterator<Item=T>

表 B-5 展示了使用特征约束来限制泛型参数的符号。

表 B-5: 特征约束

符号 解释
T: U 泛型参数 T需实现U类型
T: 'a 泛型 T 的生命周期必须长于 'a(意味着该类型不能传递包含生命周期短于 'a 的任何引用)
T : 'static 泛型 T只能使用声明周期为'static的引用
'b: 'a 生命周期'b必须长于生命周期'a
T: ?Sized 使用一个不定大小的泛型类型
'a + trait, trait + trait 多个类型组成的复合类型限制

表 B-6 展示了宏以及在一个对象上定义属性的符号。

表 B-6: 宏与属性

符号 解释
#[meta] 外部属性
#![meta] 内部属性
$ident 宏替换
$ident:kind 宏捕获
$(…)… 宏重复
ident!(...), ident!{...}, ident![...] 宏调用

表 B-7 展示了写注释的符号。

表 B-7: 注释

符号 注释
// 行注释
//! 内部行(hang)文档注释
/// 外部行文档注释
/*...*/ 块注释
/*!...*/ 内部块文档注释
/**...*/ 外部块文档注释

表 B-8 展示了出现在使用元组时的符号。

表 B-8: 元组

符号 解释
() 空元组(亦称单元),即是字面值也是类型
(expr) 括号表达式
(expr,) 单一元素元组表达式
(type,) 单一元素元组类型
(expr, ...) 元组表达式
(type, ...) 元组类型
expr(expr, ...) 函数调用表达式;也用于初始化元组结构体 struct 以及元组枚举 enum 变体
expr.0, expr.1, etc. 元组索引

表 B-9 展示了使用大括号的上下文。

表 B-9: 大括号

符号 解释
{...} 代码块表达式
Type {...} 结构体字面值

表 B-10 展示了使用方括号的上下文。

表 B-10: 方括号

符号 解释
[...] 数组
[expr; len] 数组里包含lenexpr
[type; len] 数组里包含了lentype类型的对象
expr[expr] 集合索引。 重载(Index, IndexMut
expr[..], expr[a..], expr[..b], expr[a..b] 集合索引,也称为集合切片,索引要实现以下特征中的其中一个:RangeRangeFromRangeToRangeFull