指针类型
所有指针都是显式的一等值。它们可以被移动或复制,存储在数据结构中,并从函数返回。
引用(& 和 &mut)
Syntax
ReferenceType → & Lifetime? mut? TypeNoBounds
共享引用(&)
共享引用指向由某个其他值拥有的内存。
当创建对值的共享引用时,它会阻止值的直接修改。内部可变性在某些情况下为此提供了例外。顾名思义,可以存在任意数量的共享引用。共享引用类型写为 &type,当需要指定显式生命周期时写为 &'a type。
复制引用是“浅层“操作:它只涉及复制指针本身,也就是说,指针是 Copy 的。释放引用对其指向的值没有影响,但引用临时值将在引用本身的作用域内保持其存活。
可变引用(&mut)
可变引用指向由某个其他值拥有的内存。可变引用类型写为 &mut type 或 &'a mut type。
可变引用(未被借用的)是访问其指向的值的唯一方式,因此不是 Copy 的。
裸指针(*const 和 *mut)
Syntax
RawPointerType → * ( mut | const ) TypeNoBounds
裸指针是没有安全性或活性保证的指针。裸指针写为 *const T 或 *mut T。例如 *const i32 表示指向 32 位整数的裸指针。
复制或丢弃裸指针对任何其他值的生命周期没有影响。
解引用裸指针是[unsafe 操作]。
这也可以用于通过重新借用(&* 或 &mut *)将裸指针转换为引用。通常不鼓励使用裸指针;它们的存在是为了支持与外部代码的互操作性,以及编写性能关键或低级函数。
比较裸指针时,它们按其地址进行比较,而不是按它们指向的内容进行比较。比较指向动态大小类型的裸指针时,还会比较它们的附加数据。
裸指针可以直接使用 &raw const 创建 *const 指针,使用 &raw mut 创建 *mut 指针。
智能指针
标准库包含除引用和裸指针之外的额外“智能指针“类型。
位有效性
尽管指针和引用在大多数平台上发出的机器代码中类似于 usize,但将引用或指针类型转换为非指针类型的语义目前尚未确定。因此,将指针或引用类型 P 转换为 [u8; size_of::<P>()] 可能无效。
对于瘦裸指针(即,对于 T: Sized 的 P = *const T 或 P = *mut T),反向方向(从整数或整数数组转换为 P)始终有效。但是,通过此类转换产生的指针可能无法被解引用(即使 T 具有零大小)。