函数

同样的规则也适用于函数:在使用类型 T 前给出 <T>,那么 T 就变成了泛型。

调用泛型函数有时需要显式地指明类型参量。这可能是因为调用了返回类型是泛型的 函数,或者编译器没有足够的信息来推断类型参数。

调用函数时,使用显式指定的类型参数会像是这样:fun::<A, B, ...>()

  1. struct A; // 具体类型 `A`。
  2. struct S(A); // 具体类型 `S`。
  3. struct SGen<T>(T); // 泛型类型 `SGen`。
  4. // 下面全部函数都得到了变量的所有权,并立即使之离开作用域,将变量释放。
  5. // 定义一个函数 `reg_fn`,接受一个 `S` 类型的参数 `_s`。
  6. // 因为没有 `<T>` 这样的泛型类型参数,所以这不是泛型函数。
  7. fn reg_fn(_s: S) {}
  8. // 定义一个函数 `gen_spec_t`,接受一个 `SGen<A>` 类型的参数 `_s`。
  9. // `SGen<>` 显式地接受了类型参数 `A`,且在 `gen_spec_t` 中,`A` 没有被用作
  10. // 泛型类型参数,所以函数不是泛型的。
  11. fn gen_spec_t(_s: SGen<A>) {}
  12. // 定义一个函数 `gen_spec_i32`,接受一个 `SGen<i32>` 类型的参数 `_s`。
  13. // `SGen<>` 显式地接受了类型参量 `i32`,而 `i32` 是一个具体类型。
  14. // 由于 `i32` 不是一个泛型类型,所以这个函数也不是泛型的。
  15. fn gen_spec_i32(_s: SGen<i32>) {}
  16. // 定义一个函数 `generic`,接受一个 `SGen<T>` 类型的参数 `_s`。
  17. // 因为 `SGen<T>` 之前有 `<T>`,所以这个函数是关于 `T` 的泛型函数。
  18. fn generic<T>(_s: SGen<T>) {}
  19. fn main() {
  20. // 使用非泛型函数
  21. reg_fn(S(A)); // 具体类型。
  22. gen_spec_t(SGen(A)); // 隐式地指定类型参数 `A`。
  23. gen_spec_i32(SGen(6)); // 隐式地指定类型参数 `i32`。
  24. // 为 `generic()` 显式地指定类型参数 `char`。
  25. generic::<char>(SGen('a'));
  26. // 为 `generic()` 隐式地指定类型参数 `char`。
  27. generic(SGen('c'));
  28. }

参见:

函数structs