gpt4 book ai didi

rust - 如何定义函数类型参数(或其关联类型)的函数局部类型别名?

转载 作者:行者123 更新时间:2023-11-29 07:56:49 24 4
gpt4 key购买 nike

我有一个通用函数 foo具有一些复杂的特征界限:

use std::ops::Index;

// This trait is just as an example
trait Float {
const PI: Self;
fn from_f32(v: f32) -> Self;
}
// impl Float for f32, f64 ...

fn foo<C>(container: &C)
where
C: Index<u32>,
<C as Index<u32>>::Output: Float,
{
// ...
}

我现在需要使用类型 <C as Index<u32>>::Output在函数内部一堆(例如通过 ::PI 或说 ::from_f32(3.0) 获得 π)。但是这种类型手工输入很长,并且使整个代码非常冗长且难以阅读。 (注意:在我的真实代码中,实际类型甚至更长更难看。)

为了解决这个问题,我尝试创建一个函数本地类型别名:

// Inside of `foo`:
type Floaty = <C as Index<u32>>::Output;

但这会导致这个错误:

error[E0401]: can't use type parameters from outer function
--> src/lib.rs:16:20
|
10 | fn foo<C>(container: &C)
| --- - type variable from outer function
| |
| try adding a local type parameter in this method instead
...
16 | type Floaty = <C as Index<u32>>::Output;
| ^ use of type variable from outer function

所以,就像其他项目一样,type别名也会被处理,不管它们是否在函数中。没有任何好主意,我尝试编写一个扩展为以下类型的宏:

// Inside of `foo`:
macro_rules! Floaty {
() => { <C as Index<u32>>::Output };
}

Floaty!()::PI; // errors

虽然我在这方面取得了部分成功(Floaty!() 在某些类型上下文中有效),但最后一行错误:

error: expected one of `.`, `;`, `?`, `}`, or an operator, found `::`
--> src/lib.rs:20:14
|
20 | Floaty!()::PI; // errors
| ^^ expected one of `.`, `;`, `?`, `}`, or an operator here

error[E0575]: expected method or associated constant, found associated type `Index::Output`
--> src/lib.rs:17:17
|
17 | () => { <C as Index<u32>>::Output };
| ^^^^^^^^^^^^^^^^^^^^^^^^^
...
20 | Floaty!()::PI; // errors
| --------- in this macro invocation
|
= note: can't use a type alias as a constructor

我的尝试都没有完全奏效。 是否可以避免每次都写出完整的类型名称?

最佳答案

Diesel 也有类似的“问题”,他们已经通过 defining non-function-local type aliases 解决了它.我喜欢这个解决方案,因为您也可以使用别名来清理特征范围:

type Floaty<C> = <C as Index<u32>>::Output;

fn foo<C>(container: &C)
where
C: Index<u32>,
Floaty<C>: Float,
{
let p = Floaty::<C>::PI;
// ...
}

请注意,您必须更改特征 Float 以要求它是 Sized 才能实际运行此代码。

关于rust - 如何定义函数类型参数(或其关联类型)的函数局部类型别名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54558719/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com