Trait Borrow
trait Borrow<Borrowed: ?Sized>
A trait for borrowing data.
In Rust, it is common to provide different representations of a type for
different use cases. For instance, storage location and management for a
value can be specifically chosen as appropriate for a particular use via
pointer types such as Box<T> or Rc<T>. Beyond these generic
wrappers that can be used with any type, some types provide optional
facets providing potentially costly functionality. An example for such a
type is String which adds the ability to extend a string to the basic
str. This requires keeping additional information unnecessary for a
simple, immutable string.
These types provide access to the underlying data through references
to the type of that data. They are said to be ‘borrowed as’ that type.
For instance, a Box<T> can be borrowed as T while a String
can be borrowed as str.
Types express that they can be borrowed as some type T by implementing
Borrow<T>, providing a reference to a T in the trait’s
borrow method. A type is free to borrow as several different types.
If it wishes to mutably borrow as the type, allowing the underlying data
to be modified, it can additionally implement [BorrowMut<T>].
Further, when providing implementations for additional traits, it needs
to be considered whether they should behave identically to those of the
underlying type as a consequence of acting as a representation of that
underlying type. Generic code typically uses Borrow<T> when it relies
on the identical behavior of these additional trait implementations.
These traits will likely appear as additional trait bounds.
In particular Eq, Ord and Hash must be equivalent for
borrowed and owned values: x.borrow() == y.borrow() should give the
same result as x == y.
If generic code merely needs to work for all types that can
provide a reference to related type T, it is often better to use
[AsRef<T>] as more types can safely implement it.
Examples
As a data collection, HashMap<K, V> owns both keys and values. If
the key’s actual data is wrapped in a managing type of some kind, it
should, however, still be possible to search for a value using a
reference to the key’s data. For instance, if the key is a string, then
it is likely stored with the hash map as a String, while it should
be possible to search using a [&str]str. Thus, insert needs to
operate on a String while get needs to be able to use a &str.
Slightly simplified, the relevant parts of HashMap<K, V> look like
this:
use Borrow;
use Hash;
The entire hash map is generic over a key type K. Because these keys
are stored with the hash map, this type has to own the key’s data.
When inserting a key-value pair, the map is given such a K and needs
to find the correct hash bucket and check if the key is already present
based on that K. It therefore requires K: Hash + Eq.
When searching for a value in the map, however, having to provide a
reference to a K as the key to search for would require to always
create such an owned value. For string keys, this would mean a String
value needs to be created just for the search for cases where only a
str is available.
Instead, the get method is generic over the type of the underlying key
data, called Q in the method signature above. It states that K
borrows as a Q by requiring that K: Borrow<Q>. By additionally
requiring Q: Hash + Eq, it signals the requirement that K and Q
have implementations of the Hash and Eq traits that produce identical
results.
The implementation of get relies in particular on identical
implementations of Hash by determining the key’s hash bucket by calling
Hash::hash on the Q value even though it inserted the key based on
the hash value calculated from the K value.
As a consequence, the hash map breaks if a K wrapping a Q value
produces a different hash than Q. For instance, imagine you have a
type that wraps a string but compares ASCII letters ignoring their case:
;
Because two equal values need to produce the same hash value, the
implementation of Hash needs to ignore ASCII case, too:
# use ;
# ;
Can CaseInsensitiveString implement Borrow<str>? It certainly can
provide a reference to a string slice via its contained owned string.
But because its Hash implementation differs, it behaves differently
from str and therefore must not, in fact, implement Borrow<str>.
If it wants to allow others access to the underlying str, it can do
that via AsRef<str> which doesn’t carry any extra requirements.
Required Methods
fn borrow(self: &Self) -> &BorrowedImmutably borrows from an owned value.
Examples
use Borrow; let s = "Hello".to_string; check; let s = "Hello"; check;
Implementors
impl<T> Borrow for vector_bool_intimpl<T> Borrow for RSplitTerminator<'a, P>impl<T> Borrow for float64x1x4_timpl<T> Borrow for int32x4x4_timpl<T> Borrow for AllocErrorimpl<T> Borrow for uint32x4_timpl<T> Borrow for SplitTerminator<'a, P>impl<T> Borrow for poly16x8x4_timpl<T> Borrow for CharSliceSearcher<'a, 'b>impl<T> Borrow for poly64x2x3_timpl<T> Borrow for Scan<I, St, F>impl<T> Borrow for SplitInclusiveMut<'a, T, P>impl<T> Borrow for AddrParseErrorimpl<T> Borrow for u128impl<T> Borrow for LayoutErrorimpl<T> Borrow for UnwindActionArgimpl<T> Borrow for uint16x8x4_timpl<T> Borrow for uint64x2x3_timpl<T> Borrow for RSplit<'a, P>impl<T> Borrow for vector_bool_long_longimpl<T> Borrow for UnsafeCell<T>impl<T> Borrow for Inspect<I, F>impl<T> Borrow for boolimpl<T> Borrow for Repeat<A>impl<T> Borrow for int16x8x4_timpl<T> Borrow for u16impl<T> Borrow for int64x2x3_timpl<T> Borrow for SplitInclusive<'a, P>impl<T> Borrow for Split<'a, P>impl<T> Borrow for v128impl<T> Borrow for uint64x2_timpl<T> Borrow for poly8x16x4_timpl<T> Borrow for float32x4x3_timpl<T> Borrow for BorrowedCursor<'a>impl<T> Borrow for SocketAddrimpl<T> Borrow for vector_unsigned_longimpl<T> Borrow for SplitAsciiWhitespace<'a>impl<T> Borrow for u64impl<T> Borrow for BuildHasherDefault<H>impl<T> Borrow for Bytes<'a>impl<T> Borrow for uint8x16x4_timpl<T> Borrow for float16x8x3_timpl<T> Borrow for RefMut<'b, T>impl<T> Borrow for ManuallyDrop<T>impl<T> Borrow for Rev<T>impl<T> Borrow for PhantomData<T>impl<T> Borrow for Mask<T, N>impl<T> Borrow for m256dimpl<T> Borrow for Pending<T>impl<T> Borrow for Map<I, F>impl<T> Borrow for DebugList<'a, 'b>impl<T> Borrow for int8x16x4_timpl<T> Borrow for RangeInclusive<Idx>impl<T> Borrow for SplitWhitespace<'a>impl<T> Borrow for uint32x4x3_timpl<T> Borrow for usizeimpl<T> Borrow for RangeIter<A>impl<T> Borrow for IterMut<'a, T>impl<T> Borrow for RangeFrom<Idx>impl<T> Borrow for float64x1x3_timpl<T> Borrow for SipHasherimpl<T> Borrow for int8x8_timpl<T> Borrow for float16x8_timpl<T> Borrow for int32x4x3_timpl<T> Borrow for MaybeDangling<P>impl<T> Borrow for GetDisjointMutErrorimpl<T> Borrow for LinesAny<'a>impl<T> Borrow for Utf8Pattern<'a>impl<T> Borrow for Wrapping<T>impl<T> Borrow for Chars<'a>impl<T> Borrow for poly16x8x3_timpl<T> Borrow for u32impl<T> Borrow for Cycle<I>impl<T> Borrow for SplitMut<'a, T, P>impl<T> Borrow for ChunkByMut<'a, T, P>impl<T> Borrow for AtomicU32impl<T> Borrow for RSplitN<'a, T, P>impl<T, N: usize> Borrow for [T; N]impl<T> Borrow for ParseBoolErrorimpl<T> Borrow for uint16x8x3_timpl<T> Borrow for AtomicIsizeimpl<T> Borrow for isizeimpl<T> Borrow for SplitInclusive<'a, T, P>impl<T> Borrow for Iter<'a, A>impl<T> Borrow for FormattingOptionsimpl<T> Borrow for int16x4_timpl<T> Borrow for int16x8x3_timpl<T> Borrow for FromBytesWithNulErrorimpl<T> Borrow for RangeInclusiveIter<A>impl<T> Borrow for [MaybeUninit<T>; N]impl<T> Borrow for Split<'a, T, P>impl<T> Borrow for poly8x16x3_timpl<T> Borrow for Enumerate<I>impl<T> Borrow for LaneCount<N>impl<T> Borrow for m128dimpl<T> Borrow for uint8x16x3_timpl<T> Borrow for Fuse<I>impl<T> Borrow for __m128dimpl<T> Borrow for IntoIter<A>impl<T> Borrow for int32x2_timpl<T> Borrow for int8x16x3_timpl<T> Borrow for Chain<A, B>impl<T> Borrow for vector_bool_charimpl<T> Borrow for *const Timpl<T> Borrow for RChunksMut<'a, T>impl<T> Borrow for poly64x2x2_timpl<T> Borrow for IterMut<'a, A>impl<T> Borrow for Discriminant<T>impl<T> Borrow for [T]impl<T> Borrow for uint64x2x2_timpl<T> Borrow for (T)impl<T> Borrow for RChunks<'a, T>impl<T> Borrow for ChunkBy<'a, T, P>impl<T> Borrow for __m256dimpl<T> Borrow for int64x2x2_timpl<T> Borrow for FilterMap<I, F>impl<T> Borrow for Alignmentimpl<T> Borrow for CoroutineState<Y, R>impl<T> Borrow for int64x1_timpl<T> Borrow for vector_bool_shortimpl<T> Borrow for float32x4x2_timpl<T> Borrow for ParseIntErrorimpl<T> Borrow for OptionFlatten<A>impl<T> Borrow for CStrimpl<T> Borrow for PhantomContravariant<T>impl<T> Borrow for RepeatN<A>impl<T> Borrow for Reverse<T>impl<T> Borrow for vector_unsigned_charimpl<T> Borrow for MapWindows<I, F, N>impl<T> Borrow for bf16impl<T> Borrow for CharIndices<'a>impl<T> Borrow for u8impl<T> Borrow for float16x8x2_timpl<T> Borrow for ByteStrimpl<T> Borrow for Copied<I>impl<T> Borrow for RChunksExact<'a, T>impl<T> Borrow for BorrowedBuf<'data>impl<T> Borrow for __m512dimpl<T> Borrow for SocketAddrV4impl<T> Borrow for uint32x4x2_timpl<T> Borrow for int8x16_timpl<T> Borrow for Ref<'b, T>impl<T> Borrow for AtomicI16impl<T> Borrow for Alignmentimpl<T> Borrow for vector_bool_intimpl<T> Borrow for float64x1x2_timpl<T> Borrow for Fieldimpl<T> Borrow for f16impl<T> Borrow for int32x4x2_timpl<T> Borrow for Lines<'a>impl<T> Borrow for FromBytesUntilNulErrorimpl Borrow for ByteStrimpl<T> Borrow for ChunksMut<'a, T>impl<T> Borrow for vector_unsigned_shortimpl<T> Borrow for FromIter<I>impl<T> Borrow for RangeFromIter<A>impl<T> Borrow for PhantomPinnedimpl<T> Borrow for poly16x8x2_timpl<T> Borrow for SimdAlignimpl<T> Borrow for c_voidimpl<T> Borrow for RMatches<'a, P>impl<T> Borrow for __m512bhimpl<T> Borrow for Chunks<'a, T>impl<T> Borrow for uint16x8x2_timpl<T> Borrow for ArrayWindows<'a, T, N>impl<T> Borrow for int16x8_timpl<T> Borrow for ContextBuilder<'a>impl<T> Borrow for int16x8x2_timpl<T> Borrow for Arguments<'a>impl<T> Borrow for vector_unsigned_intimpl<T> Borrow for poly8x16x2_timpl<T> Borrow for DecodeUtf16<I>impl<T> Borrow for FlatMap<I, U, F>impl<T> Borrow for __m512himpl<T> Borrow for ChunksExact<'a, T>impl<T> Borrow for uint8x16x2_timpl<T> Borrow for TakeWhile<I, P>impl<T> Borrow for int32x4_timpl<T> Borrow for CharArrayRefSearcher<'a, 'b, N>impl<T> Borrow for Layoutimpl<T> Borrow for IntersperseWith<I, G>impl<T> Borrow for Orderingimpl<T> Borrow for int8x16x2_timpl<T> Borrow for vector_unsigned_long_longimpl<T> Borrow for Source<'a>impl<T> Borrow for SplitN<'a, T, P>impl<T> Borrow for EscapeUnicode<'a>impl<T> Borrow for Zip<A, B>impl<T> Borrow for FromFn<F>impl<T> Borrow for RChunksExactMut<'a, T>impl<T> Borrow for int64x2_timpl<T> Borrow for vector_signed_longimpl<T> Borrow for Windows<'a, T>impl<T> Borrow for SearchStepimpl<T> Borrow for ReturnToArgimpl<T> Borrow for vector_doubleimpl<T> Borrow for ToUppercaseimpl<T> Borrow for m256impl<T> Borrow for Formatter<'a>impl<T> Borrow for float16x4_timpl<T> Borrow for ()impl<T> Borrow for objc_selectorimpl<T> Borrow for FromFn<F>impl<T> Borrow for vector_doubleimpl<T> Borrow for Yeet<T>impl<T> Borrow for PanicInfo<'a>impl<T> Borrow for poly64x1x4_timpl<T> Borrow for Exclusive<T>impl<T> Borrow for Bound<T>impl<T> Borrow for TypeIdimpl<T> Borrow for objc_classimpl<T> Borrow for Pin<Ptr>impl<T> Borrow for Utf8Errorimpl<T> Borrow for uint64x1x4_timpl<T> Borrow for VaList<'a>impl<T> Borrow for Request<'a>impl<T> Borrow for poly8x8_timpl<T> Borrow for Matches<'a, P>impl<T> Borrow for int64x1x4_timpl<T> Borrow for Poll<T>impl<T> Borrow for Successors<T, F>impl<T> Borrow for float32x2x4_timpl<T> Borrow for Bytes<'a>impl<T> Borrow for m128impl<T> Borrow for float16x4x4_timpl<T> Borrow for IntoIter<T>impl<T> Borrow for __m128impl<T> Borrow for Utf8Chunks<'a>impl<T> Borrow for UnsafePinned<T>impl<T> Borrow for float64x2x4_timpl<T> Borrow for PhantomCovariant<T>impl<T> Borrow for IntErrorKindimpl<T> Borrow for poly16x4_timpl<T> Borrow for uint32x2x4_timpl<T> Borrow for MapWhile<I, P>impl<T> Borrow for vector_unsigned_charimpl<T> Borrow for RawWakerVTableimpl<T> Borrow for Peekable<I>impl<T> Borrow for Wakerimpl<T> Borrow for float64x2_timpl<T> Borrow for int32x2x4_timpl<T> Borrow for RangeFrom<Idx>impl<T> Borrow for StepBy<I>impl<T> Borrow for RawWakerimpl<T> Borrow for poly16x4x4_timpl<T> Borrow for poly64x1x3_timpl<T> Borrow for StrSearcher<'a, 'b>impl<T> Borrow for Intersperse<I>impl<T> Borrow for DebugStruct<'a, 'b>impl<T> Borrow for __m256impl<T> Borrow for float32x2_timpl<T> Borrow for uint16x4x4_timpl<T> Borrow for Location<'a>impl<T> Borrow for uint64x1x3_timpl<T> Borrow for CpuidResultimpl<T> Borrow for AtomicU8impl<T> Borrow for vector_unsigned_shortimpl<T> Borrow for ChunksExactMut<'a, T>impl<T> Borrow for EscapeDefault<'a>impl<T> Borrow for AtomicI32impl<T> Borrow for Arrayimpl<T> Borrow for int16x4x4_timpl<T> Borrow for int64x1x3_timpl<T> Borrow for vector_signed_charimpl<T> Borrow for RefCell<T>impl<T> Borrow for AtomicU64impl<T> Borrow for poly8x8x4_timpl<T> Borrow for float32x2x3_timpl<T> Borrow for AtomicOrderingimpl<T> Borrow for ArrayChunks<I, N>impl<T> Borrow for __m512impl<T> Borrow for EscapeAscii<'a>impl<T> Borrow for poly64x1_timpl<T> Borrow for uint8x8x4_timpl<T> Borrow for float16x4x3_timpl<T> Borrow for TryFromFloatSecsErrorimpl<T> Borrow for vector_unsigned_intimpl<T> Borrow for Utf8Chunk<'a>impl<T> Borrow for float64x2x3_timpl<T> Borrow for int8x8x4_timpl<T> Borrow for uint32x2x3_timpl<T> Borrow for vector_signed_shortimpl<T> Borrow for BorrowMutErrorimpl<T> Borrow for int32x2x3_timpl<T> Borrow for RSplitMut<'a, T, P>impl<T> Borrow for EscapeDefaultimpl<T> Borrow for BasicBlockimpl<T> Borrow for __m256bhimpl<T> Borrow for BorrowErrorimpl<T> Borrow for poly8x16_timpl<T> Borrow for poly16x4x3_timpl<T> Borrow for RangeTo<Idx>impl<T> Borrow for RMatchIndices<'a, P>impl<T> Borrow for SkipWhile<I, P>impl<T> Borrow for RSplitNMut<'a, T, P>impl<T> Borrow for uint16x4x3_timpl<T> Borrow for vector_signed_intimpl<T> Borrow for neverimpl<T> Borrow for int16x4x3_timpl<T> Borrow for AsciiCharimpl<T> Borrow for RepeatWith<F>impl<T> Borrow for __m256himpl<T> Borrow for IterMut<'a, T>impl<T> Borrow for poly16x8_timpl<T> Borrow for poly8x8x3_timpl<T> Borrow for CharArraySearcher<'a, N>impl<T: ?Sized> Borrow for Timpl<T> Borrow for uint8x8x3_timpl<T> Borrow for vector_signed_long_longimpl<T> Borrow for PhantomInvariantLifetime<'a>impl<T> Borrow for int8x8x3_timpl<T> Borrow for FpCategoryimpl<T> Borrow for poly64x1x2_timpl<T> Borrow for TypeKindimpl<T> Borrow for Errorimpl<T> Borrow for TryFromIntErrorimpl<T> Borrow for float32x4_timpl<T> Borrow for CharPredicateSearcher<'a, F>impl<T> Borrow for SyncUnsafeCell<T>impl<T> Borrow for IntoIter<T, N>impl<T> Borrow for uint64x1x2_timpl<T> Borrow for PanicMessage<'a>impl<T> Borrow for Infallibleimpl<T> Borrow for Lastimpl<T> Borrow for vector_floatimpl<T> Borrow for DebugAsHeximpl<T> Borrow for m256iimpl<T> Borrow for int64x1x2_timpl<T> Borrow for TryFromSliceErrorimpl<T> Borrow for float32x2x2_timpl<T> Borrow for poly64x2_timpl<T> Borrow for OnceCell<T>impl<T> Borrow for DebugMap<'a, 'b>impl<T> Borrow for vector_bool_longimpl<T> Borrow for float16x4x2_timpl<T> Borrow for Iter<'a, T>impl<T> Borrow for Flatten<I>impl<T> Borrow for Ipv4Addrimpl<T> Borrow for float64x2x2_timpl<T> Borrow for Skip<I>impl<T> Borrow for uint32x2x2_timpl<T> Borrow for Cell<T>impl<T> Borrow for Result<T, E>impl<T> Borrow for DropGuard<T, F>impl<T> Borrow for f16x2impl<T> Borrow for f128impl<T> Borrow for int32x2x2_timpl<T> Borrow for LazyCell<T, F>impl<T> Borrow for RSplit<'a, T, P>impl<T> Borrow for uint8x8_timpl<T> Borrow for SYimpl<T> Borrow for f64impl<T> Borrow for EscapeDebug<'a>impl<T> Borrow for poly16x4x2_timpl<T> Borrow for Localityimpl<T> Borrow for RangeInclusive<Idx>impl<T> Borrow for MatchIndices<'a, P>impl<T> Borrow for Orderingimpl<T> Borrow for i8impl<T> Borrow for uint16x4x2_timpl<T> Borrow for m128iimpl<T> Borrow for NonZero<T>impl<T> Borrow for Iter<'a, T>impl<T> Borrow for Signimpl<T> Borrow for __m128iimpl<T> Borrow for Ipv6MulticastScopeimpl<T> Borrow for int16x4x2_timpl<T> Borrow for DebugTuple<'a, 'b>impl<T> Borrow for charimpl<T> Borrow for uint16x4_timpl<T> Borrow for i64impl<T> Borrow for UnwindTerminateReasonimpl<T> Borrow for AtomicI8impl<T: ?Sized> Borrow for &Timpl<T> Borrow for vector_signed_charimpl<T> Borrow for Range<Idx>impl<T> Borrow for Saturating<T>impl<T> Borrow for poly8x8x2_timpl<T> Borrow for RangeToInclusive<Idx>impl<T> Borrow for ToLowercaseimpl<T> Borrow for float64x1_timpl<T> Borrow for i16impl<T> Borrow for ParseCharErrorimpl<T> Borrow for ByRefSized<'a, I>impl<T> Borrow for AtomicI64impl<T> Borrow for uint8x8x2_timpl<T> Borrow for fn(_: T) -> Retimpl<T> Borrow for DynMetadata<Dyn>impl<T> Borrow for AtomicUsizeimpl<T> Borrow for Ipv6Addrimpl<T> Borrow for __m256iimpl<T> Borrow for int8x8x2_timpl<T> Borrow for RangeToInclusive<Idx>impl<T> Borrow for Clamp<Idx>impl<T> Borrow for uint32x2_timpl<T> Borrow for EscapeUnicodeimpl<T> Borrow for Take<I>impl<T> Borrow for vector_signed_shortimpl<T> Borrow for Context<'a>impl<T> Borrow for PhantomContravariantLifetime<'a>impl<T> Borrow for SplitNMut<'a, T, P>impl<T> Borrow for IpAddrimpl<T> Borrow for TryFromCharErrorimpl<T> Borrow for __m512iimpl<T> Borrow for uint64x1_timpl<T> Borrow for SocketAddrV6impl<T> Borrow for Durationimpl<T> Borrow for AssertUnwindSafe<T>impl<T> Borrow for EscapeDefaultimpl<T> Borrow for Cloned<I>impl<T> Borrow for NumBuffer<T>impl<T> Borrow for vector_signed_intimpl<T> Borrow for Empty<T>impl<T> Borrow for DecodeUtf16Errorimpl<T> Borrow for vector_bool_charimpl<T> Borrow for Range<Idx>impl<T> Borrow for i128impl<T> Borrow for Option<T>impl<T> Borrow for poly64x2x4_timpl<T> Borrow for NonNull<T>impl<T> Borrow for OnceWith<F>impl<T> Borrow for RangeFullimpl<T> Borrow for __m128bhimpl<T> Borrow for uint8x16_timpl<T> Borrow for i32impl<T> Borrow for uint64x2x4_timpl<T> Borrow for EscapeDebugimpl<T> Borrow for vector_floatimpl<T> Borrow for FromCoroutine<G>impl<T> Borrow for LocalWakerimpl<T> Borrow for AtomicBoolimpl<T> Borrow for Filter<I, P>impl<T> Borrow for DebugSet<'a, 'b>impl<T> Borrow for ControlFlow<B, C>impl<T> Borrow for int64x2x4_timpl<T> Borrow for EncodeUtf16<'a>impl<T> Borrow for vector_bool_shortimpl<T> Borrow for Typeimpl<T> Borrow for Once<T>impl<T> Borrow for RSplitN<'a, P>impl<T> Borrow for float32x4x4_timpl<T> Borrow for CharTryFromErrorimpl<T> Borrow for AtomicPtr<T>impl<T> Borrow for OneSidedRangeBoundimpl<T> Borrow for Ready<T>impl<T> Borrow for Assumeimpl<T> Borrow for PhantomInvariant<T>impl<T: ?Sized> Borrow for &mut Timpl<T> Borrow for __m128himpl<T> Borrow for strimpl<T> Borrow for uint16x8_timpl<T> Borrow for CharSearcher<'a>impl<T> Borrow for float16x8x4_timpl<T> Borrow for PhantomCovariantLifetime<'a>impl<T> Borrow for AtomicU16impl<T> Borrow for Simd<T, N>impl<T> Borrow for Tupleimpl<T> Borrow for SplitN<'a, P>impl<T> Borrow for MaybeUninit<T>impl<T> Borrow for f32impl<T> Borrow for PollFn<F>impl<T> Borrow for uint32x4x4_t