pub trait Copy: Clone { }
Expand description
Types whose values can be duplicated simply by copying bits.
By default, variable bindings have ‘move semantics.’ In other words:
#[derive(Debug)]
struct Foo;
let x = Foo;
let y = x;
// `x` has moved into `y`, and so cannot be used
// println!("{x:?}"); // error: use of moved value
However, if a type implements Copy
, it instead has ‘copy semantics’:
// We can derive a `Copy` implementation. `Clone` is also required, as it's
// a supertrait of `Copy`.
#[derive(Debug, Copy, Clone)]
struct Foo;
let x = Foo;
let y = x;
// `y` is a copy of `x`
println!("{x:?}"); // A-OK!
It’s important to note that in these two examples, the only difference is whether you
are allowed to access x
after the assignment. Under the hood, both a copy and a move
can result in bits being copied in memory, although this is sometimes optimized away.
§How can I implement Copy
?
There are two ways to implement Copy
on your type. The simplest is to use derive
:
#[derive(Copy, Clone)]
struct MyStruct;
You can also implement Copy
and Clone
manually:
struct MyStruct;
impl Copy for MyStruct { }
impl Clone for MyStruct {
fn clone(&self) -> MyStruct {
*self
}
}
There is a small difference between the two. The derive
strategy will also place a Copy
bound on type parameters:
#[derive(Clone)]
struct MyStruct<T>(T);
impl<T: Copy> Copy for MyStruct<T> { }
This isn’t always desired. For example, shared references (&T
) can be copied regardless of
whether T
is Copy
. Likewise, a generic struct containing markers such as PhantomData
could potentially be duplicated with a bit-wise copy.
§What’s the difference between Copy
and Clone
?
Copies happen implicitly, for example as part of an assignment y = x
. The behavior of
Copy
is not overloadable; it is always a simple bit-wise copy.
Cloning is an explicit action, x.clone()
. The implementation of Clone
can
provide any type-specific behavior necessary to duplicate values safely. For example,
the implementation of Clone
for String
needs to copy the pointed-to string
buffer in the heap. A simple bitwise copy of String
values would merely copy the
pointer, leading to a double free down the line. For this reason, String
is Clone
but not Copy
.
Clone
is a supertrait of Copy
, so everything which is Copy
must also implement
Clone
. If a type is Copy
then its Clone
implementation only needs to return *self
(see the example above).
§When can my type be Copy
?
A type can implement Copy
if all of its components implement Copy
. For example, this
struct can be Copy
:
#[derive(Copy, Clone)]
struct Point {
x: i32,
y: i32,
}
A struct can be Copy
, and i32
is Copy
, therefore Point
is eligible to be Copy
.
By contrast, consider
struct PointList {
points: Vec<Point>,
}
The struct PointList
cannot implement Copy
, because Vec<T>
is not Copy
. If we
attempt to derive a Copy
implementation, we’ll get an error:
the trait `Copy` cannot be implemented for this type; field `points` does not implement `Copy`
Shared references (&T
) are also Copy
, so a type can be Copy
, even when it holds
shared references of types T
that are not Copy
. Consider the following struct,
which can implement Copy
, because it only holds a shared reference to our non-Copy
type PointList
from above:
#[derive(Copy, Clone)]
struct PointListWrapper<'a> {
point_list_ref: &'a PointList,
}
§When can’t my type be Copy
?
Some types can’t be copied safely. For example, copying &mut T
would create an aliased
mutable reference. Copying String
would duplicate responsibility for managing the
String
’s buffer, leading to a double free.
Generalizing the latter case, any type implementing Drop
can’t be Copy
, because it’s
managing some resource besides its own size_of::<T>
bytes.
If you try to implement Copy
on a struct or enum containing non-Copy
data, you will get
the error E0204.
§When should my type be Copy
?
Generally speaking, if your type can implement Copy
, it should. Keep in mind, though,
that implementing Copy
is part of the public API of your type. If the type might become
non-Copy
in the future, it could be prudent to omit the Copy
implementation now, to
avoid a breaking API change.
§Additional implementors
In addition to the implementors listed below,
the following types also implement Copy
:
- Function item types (i.e., the distinct types defined for each function)
- Function pointer types (e.g.,
fn() -> i32
) - Closure types, if they capture no value from the environment
or if all such captured values implement
Copy
themselves. Note that variables captured by shared reference always implementCopy
(even if the referent doesn’t), while variables captured by mutable reference never implementCopy
.
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.
Implementors§
impl Copy for AsciiChar
impl Copy for core::cmp::Ordering
impl Copy for Infallible
impl Copy for FromBytesWithNulError
impl Copy for core::fmt::Alignment
impl Copy for DebugAsHex
impl Copy for Sign
impl Copy for IpAddr
impl Copy for Ipv6MulticastScope
impl Copy for SocketAddr
impl Copy for FpCategory
impl Copy for IntErrorKind
impl Copy for SearchStep
impl Copy for core::sync::atomic::Ordering
impl Copy for SeekFrom
impl Copy for ErrorKind
impl Copy for Shutdown
impl Copy for BacktraceStyle
impl Copy for RecvTimeoutError
impl Copy for TryRecvError
impl Copy for num_bigfloat::defs::Error
impl Copy for RoundingMode
impl Copy for BernoulliError
impl Copy for WeightedError
impl Copy for BigEndian
impl Copy for LittleEndian
impl Copy for bool
impl Copy for char
impl Copy for f16
impl Copy for f32
impl Copy for f64
impl Copy for f128
impl Copy for i8
impl Copy for i16
impl Copy for i32
impl Copy for i64
impl Copy for i128
impl Copy for isize
impl Copy for !
impl Copy for u8
impl Copy for u16
impl Copy for u32
impl Copy for u64
impl Copy for u128
impl Copy for usize
impl Copy for BigFloat
impl Copy for ApplicationImpl
impl Copy for Global
impl Copy for Layout
impl Copy for core::alloc::AllocError
impl Copy for TypeId
impl Copy for TryFromSliceError
impl Copy for CharTryFromError
impl Copy for TryFromCharError
impl Copy for CpuidResult
impl Copy for __m128
impl Copy for __m128bh
impl Copy for __m128d
impl Copy for __m128h
impl Copy for __m128i
impl Copy for __m256
impl Copy for __m256bh
impl Copy for __m256d
impl Copy for __m256h
impl Copy for __m256i
impl Copy for __m512
impl Copy for __m512bh
impl Copy for __m512d
impl Copy for __m512h
impl Copy for __m512i
impl Copy for bf16
impl Copy for core::fmt::Error
impl Copy for FormattingOptions
impl Copy for PhantomPinned
impl Copy for Assume
impl Copy for Ipv4Addr
impl Copy for Ipv6Addr
impl Copy for SocketAddrV4
impl Copy for SocketAddrV6
impl Copy for TryFromIntError
impl Copy for RangeFull
impl Copy for core::ptr::alignment::Alignment
impl Copy for Utf8Error
impl Copy for RawWakerVTable
impl Copy for Duration
impl Copy for System
impl Copy for FileTimes
impl Copy for FileType
impl Copy for Empty
impl Copy for Sink
impl Copy for ExitCode
impl Copy for ExitStatus
impl Copy for ExitStatusError
impl Copy for DefaultRandomSource
impl Copy for RecvError
impl Copy for WaitTimeoutResult
impl Copy for AccessError
impl Copy for ThreadId
impl Copy for Instant
impl Copy for SystemTime
impl Copy for c_G_fpos64_t
impl Copy for c_G_fpos_t
impl Copy for c_IO_FILE
impl Copy for c_IO_codecvt
impl Copy for c_IO_marker
impl Copy for c_IO_wide_data
impl Copy for c__atomic_wide_counter__bindgen_ty_1
impl Copy for c__fsid_t
impl Copy for c__locale_data
impl Copy for c__locale_struct
impl Copy for c__mbstate_t
impl Copy for c__once_flag
impl Copy for c__pthread_cond_s
impl Copy for c__pthread_internal_list
impl Copy for c__pthread_internal_slist
impl Copy for c__pthread_mutex_s
impl Copy for c__pthread_rwlock_arch_t
impl Copy for c__sigset_t
impl Copy for c__va_list_tag
impl Copy for cbw_Application
impl Copy for cbw_ApplicationDispatchData
impl Copy for cbw_ApplicationEngineData
impl Copy for cbw_ApplicationEngineImpl
impl Copy for cbw_ApplicationImpl
impl Copy for cbw_ApplicationSettings
impl Copy for cbw_BrowserWindow
impl Copy for cbw_BrowserWindowEvents
impl Copy for cbw_BrowserWindowImpl
impl Copy for cbw_BrowserWindowMessageArgs
impl Copy for cbw_BrowserWindowOptions
impl Copy for cbw_BrowserWindowSource
impl Copy for cbw_CStrSlice
impl Copy for cbw_Cookie
impl Copy for cbw_CookieImpl
impl Copy for cbw_CookieIterator
impl Copy for cbw_CookieIteratorImpl
impl Copy for cbw_CookieJar
impl Copy for cbw_CookieJarImpl
impl Copy for cbw_Dims2D
impl Copy for cbw_Err
impl Copy for cbw_Event
impl Copy for cbw_Pos2D
impl Copy for cbw_StrSlice
impl Copy for cbw_Window
impl Copy for cbw_WindowDispatchData
impl Copy for cbw_WindowImpl
impl Copy for cbw_WindowOptions
impl Copy for cdiv_t
impl Copy for cdrand48_data
impl Copy for cfd_set
impl Copy for cldiv_t
impl Copy for clldiv_t
impl Copy for cmax_align_t
impl Copy for crandom_data
impl Copy for ctimespec
impl Copy for ctimeval
impl Copy for Canceled
impl Copy for getrandom::error::Error
impl Copy for Number
impl Copy for NumberOutOfScope
impl Copy for Short
impl Copy for G0
impl Copy for G1
impl Copy for GenericMachine
impl Copy for u32x4_generic
impl Copy for u64x2_generic
impl Copy for u128x1_generic
impl Copy for vec256_storage
impl Copy for vec512_storage
impl Copy for Bernoulli
impl Copy for Open01
impl Copy for OpenClosed01
impl Copy for Alphanumeric
impl Copy for Standard
impl Copy for UniformChar
impl Copy for UniformDuration
impl Copy for OsRng
impl Copy for IgnoredAny
impl Copy for zerocopy::error::AllocError
impl Copy for c__atomic_wide_counter
impl Copy for c__mbstate_t__bindgen_ty_1
impl Copy for cpthread_attr_t
impl Copy for cpthread_barrier_t
impl Copy for cpthread_barrierattr_t
impl Copy for cpthread_cond_t
impl Copy for cpthread_condattr_t
impl Copy for cpthread_mutex_t
impl Copy for cpthread_mutexattr_t
impl Copy for cpthread_rwlock_t
impl Copy for cpthread_rwlockattr_t
impl Copy for vec128_storage
impl<'a> Copy for Utf8Pattern<'a>
impl<'a> Copy for Component<'a>
impl<'a> Copy for Prefix<'a>
impl<'a> Copy for Unexpected<'a>
impl<'a> Copy for Arguments<'a>
impl<'a> Copy for PhantomContravariantLifetime<'a>
impl<'a> Copy for PhantomCovariantLifetime<'a>
impl<'a> Copy for PhantomInvariantLifetime<'a>
impl<'a> Copy for Location<'a>
impl<'a> Copy for IoSlice<'a>
impl<'a> Copy for Ancestors<'a>
impl<'a> Copy for PrefixComponent<'a>
impl<'a, E> Copy for BytesDeserializer<'a, E>
impl<'a, T> Copy for Slice<'a, T>where
T: Copy,
impl<'a, T, I> Copy for Ptr<'a, T, I>where
T: 'a + ?Sized,
I: Invariants<Aliasing = Shared>,
SAFETY: Shared pointers are safely Copy
. Ptr
’s other invariants
(besides aliasing) are unaffected by the number of references that exist
to Ptr
’s referent. The notable cases are:
-
Alignment is a property of the referent type (
T
) and the address, both of which are unchanged -
Let
S(T, V)
be the set of bit values permitted to appear in the referent of aPtr<T, I: Invariants<Validity = V>>
. Since this copy does not changeI::Validity
orT
,S(T, I::Validity)
is also unchanged.We are required to guarantee that the referents of the original
Ptr
and of the copy (which, of course, are actually the same since they live in the same byte address range) both remain in the setS(T, I::Validity)
. Since this invariant holds on the originalPtr
, it cannot be violated by the originalPtr
, and thus the originalPtr
cannot be used to violate this invariant on the copy. The inverse holds as well.
impl<'a, T, const N: usize> Copy for ArrayWindows<'a, T, N>where
T: Copy + 'a,
impl<'de, E> Copy for BorrowedBytesDeserializer<'de, E>
impl<'de, E> Copy for BorrowedStrDeserializer<'de, E>
impl<'de, E> Copy for StrDeserializer<'de, E>
impl<'handle> Copy for BorrowedHandle<'handle>
impl<'socket> Copy for BorrowedSocket<'socket>
impl<B, C> Copy for ControlFlow<B, C>
impl<B, T> Copy for Ref<B, T>
impl<Dyn> Copy for DynMetadata<Dyn>where
Dyn: ?Sized,
impl<E> Copy for BoolDeserializer<E>
impl<E> Copy for CharDeserializer<E>
impl<E> Copy for F32Deserializer<E>
impl<E> Copy for F64Deserializer<E>
impl<E> Copy for I8Deserializer<E>
impl<E> Copy for I16Deserializer<E>
impl<E> Copy for I32Deserializer<E>
impl<E> Copy for I64Deserializer<E>
impl<E> Copy for I128Deserializer<E>
impl<E> Copy for IsizeDeserializer<E>
impl<E> Copy for U8Deserializer<E>
impl<E> Copy for U16Deserializer<E>
impl<E> Copy for U32Deserializer<E>
impl<E> Copy for U64Deserializer<E>
impl<E> Copy for U128Deserializer<E>
impl<E> Copy for UnitDeserializer<E>
impl<E> Copy for UsizeDeserializer<E>
impl<F> Copy for RepeatWith<F>where
F: Copy,
impl<Idx> Copy for RangeTo<Idx>where
Idx: Copy,
impl<Idx> Copy for RangeToInclusive<Idx>where
Idx: Copy,
impl<Idx> Copy for Range<Idx>where
Idx: Copy,
impl<Idx> Copy for RangeFrom<Idx>where
Idx: Copy,
impl<Idx> Copy for RangeInclusive<Idx>where
Idx: Copy,
impl<O> Copy for F32<O>where
O: Copy,
impl<O> Copy for F64<O>where
O: Copy,
impl<O> Copy for I16<O>where
O: Copy,
impl<O> Copy for I32<O>where
O: Copy,
impl<O> Copy for I64<O>where
O: Copy,
impl<O> Copy for I128<O>where
O: Copy,
impl<O> Copy for Isize<O>where
O: Copy,
impl<O> Copy for U16<O>where
O: Copy,
impl<O> Copy for U32<O>where
O: Copy,
impl<O> Copy for U64<O>where
O: Copy,
impl<O> Copy for U128<O>where
O: Copy,
impl<O> Copy for Usize<O>where
O: Copy,
impl<Ptr> Copy for Pin<Ptr>where
Ptr: Copy,
impl<T> Copy for Option<T>where
T: Copy,
impl<T> Copy for Bound<T>where
T: Copy,
impl<T> Copy for Poll<T>where
T: Copy,
impl<T> Copy for SendTimeoutError<T>where
T: Copy,
impl<T> Copy for TrySendError<T>where
T: Copy,
impl<T> Copy for *const Twhere
T: ?Sized,
impl<T> Copy for *mut Twhere
T: ?Sized,
impl<T> Copy for &Twhere
T: ?Sized,
Shared references can be copied, but mutable references cannot!