如何在单个生锈函数中接受str,String和&String

问题描述 投票:4回答:1

我想编写一个函数,它接受一个“str”,一个“String”和一个借来的“&String”。 我写了以下两个函数:

fn accept_str_and_ref_string(value: &str)
{
    println!("value: {}", value);
}

fn accept_str_and_string<S: Into<String>>(value: S)
{
    let string_value: String = value.into();
    println!("string_value: {}", string_value);
}

fn main() {
    let str_foo = "foo";
    let string_foo = String::from("foo");

    accept_str_and_ref_string(str_foo);
    accept_str_and_ref_string(&string_foo);

    accept_str_and_string(str_foo);
    accept_str_and_string(string_foo);
}

但我希望它在1个函数中,以便我可以这样做:

accept_all_strings(str_foo);
accept_all_strings(&string_foo);
accept_all_strings(string_foo);

这可能吗?

rust borrowing
1个回答
7
投票

你可以使用AsRef<str>特质:

// will accept any object that implements AsRef<str>
fn print<S: AsRef<str>>(stringlike: S) {
    // call as_ref() to get a &str
    let str_ref = stringlike.as_ref();

    println!("got: {:?}", str_ref)
}

fn main() {
    let a: &str = "str";
    let b: String = String::from("String");
    let c: &String = &b;

    print(a);
    print(c);
    print(b);
}

print函数将支持任何实现AsRef<str>的类型,其中包括&strString&String

© www.soinside.com 2019 - 2024. All rights reserved.