Deref coercion(自动解引用类型转换)精制总结
- 语法功能:
 
- 实现【解引用】操作符
*在自定义【智能指针】上的行为。从而,使【智能指针】如同【普通引用】一样使用。 
- 实质能力:
 ![[Rust笔记]`Deref coercion`(自动解引用类型转换)精制总结_成员方法](https://file.cfanz.cn/uploads/png/2022/06/29/0/518DdW3b12.png)
自动触发场景:
先对
A类型实例完成Deref::deref(&A)处理和返回&B(或DerefMut::deref_mut(&mut A)返回&mut B)再对
B类型实例的引用&B执行解引用操作*,得到B实例在
A类型实例上用.操作符调用B类型实例上的成员方法。
newtype设计模式利用这个技术点实现从外层包装类(即,智能指针)直接调用内部私有数据类型(被指向数据)的成员方法。![[Rust笔记]`Deref coercion`(自动解引用类型转换)精制总结_成员方法_02](https://file.cfanz.cn/uploads/png/2022/06/29/0/749126BD1O.png)
成员方法调用 [例程2]
解引用操作。即,*A = B [例程3],因为这实际执行了两步操作:
触发次数
&B满足·函数签名中形参的类型要求 --- 函数调用场景在
&B上·找到了·被调用的成员方法 --- 成员方法调用场景
B未实现Deref / DerefMut trait,不再具备继续递归的条件。若
A与B都满足Deref / DerefMut trait限定条件,那么A -> &B的【解引用-类型转换】将被递归地连续执行,直至如下三个条件之一被达成,而结束递归:执行时间点
编译时,而不是运行时 --- 这又是一个零成本抽象。
将A类型的实例转换成B类型实例的引用,只要A与B类型之间满足A: Deref<Target = B>或A: DerefMut<Target = B>。更具体的描述,请见下表:
函数调用 [例程1]
需要注意的只有一点:函数的实参必须是【智能指针】的【引用】(而不是【智能指针】自身)才可触发Deref coercion。










