Copyright © 2022-2025 aizws.net · 网站版本: v1.2.6·内部版本: v1.23.4·
页面加载耗时 0.00 毫秒·物理内存 70.3MB ·虚拟内存 1300.8MB
欢迎来到 AI 中文社区(简称 AI 中文社),这里是学习交流 AI 人工智能技术的中文社区。 为了更好的体验,本站推荐使用 Chrome 浏览器。
和函数类似,impl 块要想实现泛型,也需要很仔细。
#![allow(unused)] fn main() { struct S; // 具体类型 `S` struct GenericVal <T>(T,); // 泛型类型 `GenericVal` // GenericVal 的 `impl`,此处我们显式地指定了类型参数: impl GenericVal <f32> {} // 指定 `f32` 类型 impl GenericVal <S> {} // 指定为上面定义的 `S` // ` <T>` 必须在类型之前写出来,以使类型 `T` 代表泛型。 impl <T> GenericVal <T> {} }
struct Val { val: f64 } struct GenVal <T>{ gen_val: T } // Val 的 `impl` impl Val { fn value(&self) -> &f64 { &self.val } } // GenVal 的 `impl`,指定 `T` 是泛型类型 impl <T> GenVal <T> { fn value(&self) -> &T { &self.gen_val } } fn main() { let x = Val { val: 3.0 }; let y = GenVal { gen_val: 3i32 }; println!("{}, {}", x.value(), y.value()); }
当然 trait 也可以是泛型的。我们在这里定义了一个 trait,它把 Drop trait作为泛型方法实现了,可以 drop(丢弃)调用者本身和一个输入参数。// 不可复制的类型。struct Empty;stru ...
全部【编程教程】内容源自网络,仅供学习用途,若有遗漏或版权任何问题,请及时【联系我们】 ,按下 Ctrl+D 或 ⌘+D 收藏本站。