Auto merge of #116325 - scottmcm:addr_eq, r=dtolnay
Add `ptr::addr_eq` Seconded ACP: https://github.com/rust-lang/libs-team/issues/274#issuecomment-1741853598 Tracking issue: https://github.com/rust-lang/rust/issues/116324 cc `@dtolnay` https://github.com/rust-lang/rust/issues/106447
This commit is contained in:
commit
15783292e5
@ -1868,6 +1868,28 @@ pub fn eq<T: ?Sized>(a: *const T, b: *const T) -> bool {
|
||||
a == b
|
||||
}
|
||||
|
||||
/// Compares the *addresses* of the two pointers for equality,
|
||||
/// ignoring any metadata in fat pointers.
|
||||
///
|
||||
/// If the arguments are thin pointers of the same type,
|
||||
/// then this is the same as [`eq`].
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
/// ```
|
||||
/// #![feature(ptr_addr_eq)]
|
||||
///
|
||||
/// let whole: &[i32; 3] = &[1, 2, 3];
|
||||
/// let first: &i32 = &whole[0];
|
||||
/// assert!(std::ptr::addr_eq(whole, first));
|
||||
/// assert!(!std::ptr::eq::<dyn std::fmt::Debug>(whole, first));
|
||||
/// ```
|
||||
#[unstable(feature = "ptr_addr_eq", issue = "116324")]
|
||||
#[inline(always)]
|
||||
pub fn addr_eq<T: ?Sized, U: ?Sized>(p: *const T, q: *const U) -> bool {
|
||||
(p as *const ()) == (q as *const ())
|
||||
}
|
||||
|
||||
/// Hash a raw pointer.
|
||||
///
|
||||
/// This can be used to hash a `&T` reference (which coerces to `*const T` implicitly)
|
||||
|
Loading…
Reference in New Issue
Block a user