You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardexpand all lines: src/expressions/operator-expr.md
+27-8
Original file line number
Diff line number
Diff line change
@@ -478,15 +478,20 @@ unsafe {
478
478
assert_eq!(values[1], 3);
479
479
```
480
480
481
-
#### Slice DST pointer to pointer cast
481
+
#### Pointer-to-pointer cast
482
482
483
-
For slice types like `[T]` and `[U]`, the raw pointer types `*const [T]`, `*mut [T]`,
484
-
`*const [U]`, and `*mut [U]` encode the number of elements in this slice. Casts between
485
-
these raw pointer types preserve the number of elements. Note that, as a consequence,
486
-
such casts do *not* necessarily preserve the size of the pointer's referent (e.g.,
487
-
casting `*const [u16]` to `*const [u8]` will result in a raw pointer which refers to an
488
-
object of half the size of the original). The same holds for `str` and any compound type
489
-
whose unsized tail is a slice type, such as struct `Foo(i32, [u8])` or `(u64, Foo)`.
483
+
`*const T` / `*mut T` can be cast to `*const U` / `*mut U` with the following behavior:
484
+
485
+
- If `T` and `U` are both sized, the pointer is returned unchanged.
486
+
- If `T` and `U` are both unsized, the pointer is also returned unchanged.
487
+
In particular, the metadata is preserved exactly.
488
+
489
+
For instance, a cast from `*const [T]` to `*const [U]` preserves the number of elements.
490
+
Note that, as a consequence, such casts do not necessarily preserve the size of the pointer's referent
491
+
(e.g., casting `*const [u16]` to `*const [u8]` will result in a raw pointer which refers to an object of half the size of the original).
492
+
The same holds for `str` and any compound type whose unsized tail is a slice type,
493
+
such as `struct Foo(i32, [u8])` or `(u64, Foo)`.
494
+
- If `T` is unsized and `U` is sized, the cast discards all metadata that completes the wide pointer `T` and produces a thin pointer `U` consisting of the data part of the unsized pointer.
490
495
491
496
## Assignment expressions
492
497
@@ -687,3 +692,17 @@ See [this test] for an example of using this dependency.
0 commit comments