mirror of https://github.com/sunface/rust-course
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
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"..." |
字节字符串; 结果是一个 [u8] 类型而非string类型 |
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] |
数组里包含len个expr |
[type; len] |
数组里包含了len个type类型的对象 |
expr[expr] |
集合索引。 重载(Index, IndexMut) |
expr[..], expr[a..], expr[..b], expr[a..b] |
集合索引,也称为集合切片,索引要实现以下特征中的其中一个:Range,RangeFrom,RangeTo 或 RangeFull |