gpt4 book ai didi

vector - 如何将迭代器元素的类型强制转换为新类型?

转载 作者:行者123 更新时间:2023-11-29 08:28:51 25 4
gpt4 key购买 nike

用新类型做一些实验,寻找最有效、最符合人体工程学的方法来处理集合中的元素转换。对于奇异值,相当标准的类型转换特征似乎工作得很好:

pub struct Tag(String);

impl From<Tag> for String {
fn from(v: Tag) -> String {
v.0
}
}

impl From<String> for Tag {
fn from(v: String) -> Tag {
Tag(v)
}
}

impl AsRef<String> for Tag {
fn as_ref(&self) -> &String {
&self.0
}
}

impl<'a> From<&'a Tag> for String {
fn from(t: &Tag) -> String {
t.0.clone()
}
}

但是,当我想处理项目列表时,我开始遇到问题。说(为了说明的目的)我有一个处理标签的函数,以及一些处理将字符串写入数据库的更抽象的函数:

fn process_item(tags: &Vec<Tag>) {
process_array_of_strings(tags);
}

fn process_array_of_strings(strings: &Vec<String>) {
// ...
}

这不会编译,因为 Rust 不能强制转换 tagsVec<String> ,我觉得应该有一些比以下方法更容易做到这一点的方法:

fn process_item(tags: &Vec<Tag>) {
let str_tags: Vec<String> = tags.iter().map(|t| t.into()).collect();
process_array_of_strings(&str_tags);
}

...除了冗长之外,还涉及比我想要的更多的中间内存。反向转换也是一个问题,但大概会以相同的方式实现。

这里可能还有一些额外的事情在起作用,例如我是否应该发送 Vec s 的引用而不是值,以及从引用类型实现类型转换是否是个好主意。

最佳答案

简单,只需使用泛型:

pub struct Tag(String);

impl AsRef<str> for Tag {
fn as_ref(&self) -> &str {
&self.0
}
}

fn process_item(tags: &[Tag]) {
process_array_of_strings(tags);
}

fn process_array_of_strings<'a, T>(strings: &[T])
where
T: AsRef<str>,
{
// ...
}

关于vector - 如何将迭代器元素的类型强制转换为新类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56471878/

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