Copyright © 2022-2025 aizws.net · 网站版本: v1.2.6·内部版本: v1.23.4·
页面加载耗时 0.00 毫秒·物理内存 70.3MB ·虚拟内存 1300.8MB
欢迎来到 AI 中文社区(简称 AI 中文社),这里是学习交流 AI 人工智能技术的中文社区。 为了更好的体验,本站推荐使用 Chrome 浏览器。
约束也可以使用 where 分句来表达,它放在 { 的前面,而不需写在类型第一次出现 之前。另外 where 从句可以用于任意类型的限定,而不局限于类型参数本身。
where 在下面一些情况下有很用:
impl <A: TraitB + TraitC, D: TraitE + TraitF> MyTrait<A, D> for YourType {} // 使用 `where` 从句来表达约束 impl <A, D> MyTrait<A, D> for YourType where A: TraitB + TraitC, D: TraitE + TraitF {}
use std::fmt::Debug; trait PrintInOption { fn print_in_option(self); } // 这里需要一个 `where` 从句,否则就要表达成 `T: Debug`(这样意思就变了), // 或着改用另一种间接的方法。 impl<T> PrintInOption for T where Option<T>: Debug { // 我们要将 `Option<T>: Debug` 作为约束,因为那是要打印的内容。 // 否则我们会给出错误的约束。 fn print_in_option(self) { println!("{:?}", Some(self)); } } fn main() { let vec = vec![1, 2, 3]; vec.print_in_option(); }
newtype 惯用法(译注:即为不同种类的数据分别定义新的类型)能保证在编译时,提供给程序的都是正确的类型。比如说,实现一个 “年龄认证” 函数,它要求输入必须是 Years 类型。struct Year ...
全部【编程教程】内容源自网络,仅供学习用途,若有遗漏或版权任何问题,请及时【联系我们】 ,按下 Ctrl+D 或 ⌘+D 收藏本站。