如何判断一个网站是恶意网站,找施工队伍去什么网站,电商网站流程,wordpress 支付插件在 Rust 中#xff0c;实现了 Copy trait 的类型会被自动复制而不是移动。这些类型通常具有以下特点#xff1a;大小固定且在编译时已知数据完全存储在栈上浅复制和深复制效果相同基本类型#xff08;Primitive Types#xff09;所有基本类型都实现了 Copy#xff1a;
fn …在 Rust 中实现了 Copy trait 的类型会被自动复制而不是移动。这些类型通常具有以下特点大小固定且在编译时已知数据完全存储在栈上浅复制和深复制效果相同基本类型Primitive Types所有基本类型都实现了 Copyfnmain(){// 整数类型letx:i81;lety:u82;leta:i163;letb:u164;letc:i325;// 默认整数类型letd:u326;lete:i647;letf:u648;letg:i1289;leth:u12810;leti:isize11;// 平台相关指针大小letj:usize12;// 平台相关指针大小// 浮点数类型letk:f323.14;letl:f642.718;// 默认浮点数类型// 布尔类型letm:booltrue;// 字符类型letn:char;// 所有这些类型都实现了 Copyletx2x;// 复制不是移动println!({} {},x,x2);// 两者都有效}复合类型Compound Types某些复合类型也实现了 Copyfnmain(){// 元组当所有元素都实现 Copy 时lett1:(i32,f64)(42,3.14);lett2t1;// 复制println!({:?} {:?},t1,t2);// 两者都有效// 数组当元素类型实现 Copy 且大小固定时letarr1:[i32;3][1,2,3];letarr2arr1;// 复制println!({:?} {:?},arr1,arr2);// 以下会编译错误因为 String 没有实现 Copy// let bad_tuple: (String, i32) (hello.to_string(), 42);// let bad_tuple2 bad_tuple; // 错误String 没有实现 Copy}自定义类型的 Copy 实现3.1 自动派生 Copy#[derive(Copy, Clone, Debug)]structPoint{x:i32,y:i32,}#[derive(Copy, Clone, Debug)]structColor{r:u8,g:u8,b:u8,a:u8,}fnmain(){letp1Point{x:10,y:20};letp2p1;// 复制因为 Point 实现了 Copyprintln!(p1: {:?},p1);// 仍然有效println!(p2: {:?},p2);letc1Color{r:255,g:0,b:0,a:255};letc2c1;// 复制println!(c1: {:?},c1);println!(c2: {:?},c2);}3.2 不能自动实现 Copy 的情况// 以下类型不能实现 Copy// 1. 包含非 Copy 类型// 2. 可变引用// 3. 堆分配的类型#[derive(Debug)]structPerson{name:String,// String 没有实现 Copyage:u8,}implCloneforPerson{fnclone(self)-Self{Person{name:self.name.clone(),// 需要显式克隆age:self.age,// u8 是 Copy自动复制}}}// 不能派生 Copy因为包含 String// #[derive(Copy, Clone)] // 编译错误fnmain(){letp1Person{name:Alice.to_string(),age:30,};letp2p1.clone();// 必须显式克隆// let p3 p1; // 这是移动p1 不再有效}Copy 与 Clone 的区别#[derive(Debug)]structExample{data:i32,}implCloneforExample{fnclone(self)-Self{println!(克隆被调用);Example{data:self.data}}}// 实现 Copy 需要先实现 CloneimplCopyforExample{}fndemonstrate_copy_vs_clone(){lete1Example{data:42};// Copy 类型自动复制lete2e1;// 这里调用的是 Copy不是 Cloneprintln!(e1: {:?}, e2: {:?},e1,e2);// 显式调用 clone 方法lete3e1.clone();// 这里会调用 Cloneprintln!(e3: {:?},e3);}fnmain(){demonstrate_copy_vs_clone();}Copy trait 的约束要为一个类型实现 Copy必须满足以下条件类型的所有字段都必须实现 Copy类型不能实现 Drop trait#[derive(Debug)]structNonCopyable{data:Veci32,// Vec 没有实现 Copy}// 下面的实现会导致编译错误// impl Copy for NonCopyable {} // 错误NonCopyable 包含非 Copy 字段#[derive(Debug)]structResource{id:i32,}implDropforResource{fndrop(mutself){println!(释放资源 {},self.id);}}// 下面的实现会导致编译错误// impl Copy for Resource {} // 错误Resource 实现了 Drop完整示例自定义 Copy 类型usestd::fmt;#[derive(Debug, Copy, Clone)]structComplex{real:f64,imag:f64,}implComplex{fnnew(real:f64,imag:f64)-Self{Complex{real,imag}}fnadd(self,other:Complex)-Complex{Complex{real:self.realother.real,imag:self.imagother.imag,}}}implfmt::DisplayforComplex{fnfmt(self,f:mutfmt::Formatter)-fmt::Result{write!(f,{:.2} {:.2}i,self.real,self.imag)}}fnmain(){letc1Complex::new(1.0,2.0);letc2Complex::new(3.0,4.0);// 由于 Complex 实现了 Copy这里都是复制letc3c1;letc4c2;letsumc3.add(c4);println!(c1 {} (仍然有效),c1);println!(c2 {} (仍然有效),c2);println!(c3 {},c3);println!(c4 {},c4);println!(c1 c2 {},sum);}判断类型是否实现 Copyfnis_copyT:Copy(){println!(类型 T 实现了 Copy);}fncheck_types(){// 检查各种类型is_copy::i32();// ✓is_copy::f64();// ✓is_copy::bool();// ✓is_copy::char();// ✓is_copy::(i32,f64)();// ✓is_copy::[i32;5]();// ✓// 下面的会编译错误// is_copy::String(); // ✗// is_copy::Veci32(); // ✗// is_copy::mut i32(); // ✗}fnmain(){check_types();}在泛型中约束 Copy// 泛型函数要求 T 实现 CopyfnduplicateT:Copy(value:T)-(T,T){(value,value)}// 另一种写法fnduplicate2T(value:T)-(T,T)whereT:Copy,{(value,value)}fnmain(){// 这些调用都正常let(a1,a2)duplicate(42);let(b1,b2)duplicate(3.14);let(c1,c2)duplicate(x);println!({} {},a1,a2);println!({} {},b1,b2);println!({} {},c1,c2);// 下面的调用会编译错误// let s String::from(hello);// let (s1, s2) duplicate(s); // 错误String 没有实现 Copy}Copy 类型列表总结类别 具体类型 说明整数 i8, u8, i16, u16, i32, u32, i64, u64, i128, u128, isize, usize 所有整数类型浮点数 f32, f64 所有浮点数类型布尔 bool 布尔值字符 char Unicode 标量值元组 (T1, T2, …) 当所有元素都实现 Copy 时数组 [T; N] 当 T 实现 Copy 且 N 是编译时常量时指针 *const T, *mut T 原始指针不安全函数指针 fn(T1, T2) - R 函数指针空类型 () 单元类型重要例外以下类型没有实现 Copyfnmain(){// 1. String堆分配letsString::from(hello);// let s2 s; // 移动不是复制// 2. VecT堆分配letvvec![1,2,3];// let v2 v; // 移动// 3. BoxT堆分配letbBox::new(42);// let b2 b; // 移动// 4. mut T可变引用letmutx5;letrmutx;// let r2 r; // 移动// 5. RcT, ArcT引用计数usestd::rc::Rc;letrcRc::new(42);// let rc2 rc; // 移动增加引用计数}关键记忆点所有基本类型整数、浮点数、布尔、字符都实现 Copy堆分配的类型String, Vec, Box通常不实现 Copy要自动派生 Copy类型的所有字段都必须实现 Copy实现了 Drop trait 的类型不能实现 CopyCopy 是标记 trait没有方法它依赖于 Clone trait