- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Rust String 同时实现了 AsRef<str>和 AsRef<[u8]>
但为什么 Rust 正确地允许 String 被借用为 &str 而不是 &[u8] 即使我们提供了显式类型注释提示?
let s = String::from("hello");
let item: &str = &s; // Works
let item2: &[u8] = &s; // Fails
当然显式调用有效,但很好奇为什么上面不起作用
let item2: &[u8] = s.as_ref();
最佳答案
当 &String
强制转换为 &str
时,这是通过 Deref
发生的特征(不是 AsRef
,也不是 Borrow
)。 Deref
特性不是通用的——它只允许选择一个类型来“取消引用”。对于 String
,就是 str
。
AsRef
和Borrow
特征对编译器来说并不特殊。它们可供通用代码显式使用,而不是隐式使用。
关于Rust String AsRef<T> 不会自动借用 [u8],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74201661/
我正在使用std::fs中的函数,这些函数带有path: impl AsRef之类的参数。我希望使自己的函数具有多态性,以便它们也可以采用任何impl AsRef而不是仅接受&str。但是,所讨论的类
如果我有一个包含这样的引用的结构: struct Struct { reference: &'a str } 如何为 Struct 实现 AsRef?我试过这个: impl AsRef> fo
我需要创建用于与 FFI 接口(interface)的 NewType 包装器。我想创建一个类似于 Rust 的 String 和 str 类型的接口(interface),所以我可以有一个拥有类型的
我有一个围绕 &str 的包装器来保持不变量。当我尝试返回一个新的包装器时,该包装器基本上将参数包装的相同数据包装到函数中( playground ),我收到“无法返回引用函数参数 s 的值” str
playground use std::path::Path; // fn f1(p: AsRef) { // println!("{}", p.as_ref().display()); //
我很难理解如何在下面的代码中使用生命周期。我知道明确的生命周期对于帮助编译器理解它何时可以保存/释放数据是必要的,但在这种特殊情况下, url.serialize() 生成一个匿名字符串,我不太确定如
我很难获得 AsRef以干净的方式工作。 const DEFAULT: &str = "lib"; use std::path::{Path, PathBuf}; fn extend(p: &Path
我正在尝试编写一个连接两个可迭代对象的函数,这两个可迭代对象的项目可以转换为 OsStr 引用,并且在尝试指定引用的生命周期时遇到了巨大的困难。 use std::convert::AsRef; us
以下代码显示了问题的来源。自 as_slice()已弃用,as_ref()建议作为替代品。 但是,在这种情况下使用它时,需要类型注释。 let s = "Hi"; // Thi
我在 Rust stable(截至目前,版本 1.2)中定义了一个 crate API,并且对定义我自己的类字符串类型的最佳实践感到困惑。 例如,我有一个包装字符串的 Foo 类型。 pub stru
这是我在我的 Rust 版本中看到的实现: #[stable(feature = "rust1", since = "1.0.0")] impl AsRef for PathBuf { #[i
我想写一个可以直接接受字符串切片的特征: use std::path::Path; trait Trait1 {} impl Trait1 for str {} // impl Trait1 for
Rust String 同时实现了 AsRef和 AsRef 但为什么 Rust 正确地允许 String 被借用为 &str 而不是 &[u8] 即使我们提供了显式类型注释提示? let s = S
AsRef 文档写道 Used to do a cheap reference-to-reference conversion. 我理解 reference-to-reference 部分 cheap
AsRef 有糖分吗?最好在稳定版。 我经常使用 as ref 声明类似字符串的参数,以便更轻松地与各种字符串(String、&str、&String 等)互操作: fn Fun>(my: S) {
AsRef 有糖分吗?最好在稳定版。 我经常使用 as ref 声明类似字符串的参数,以便更轻松地与各种字符串(String、&str、&String 等)互操作: fn Fun>(my: S) {
此代码无法编译: fn ref_on_int(_: T) where T: AsRef {} fn main() { ref_on_int(&0_i32) } 因为 the trait bou
我正在调用一个接受&[&str] 的函数。由于编写 ["aa", "bb"] 更方便,而不是 &["aa", "bb"],我决定添加 作为引用: struct Builder { s: Opt
我有一个将一些功能包装在切片周围的结构: use std::fmt::Debug; struct SliceWrapper { slice: &'a [T], pos: usize,
我有一个函数需要 AsRef作为参数,看起来像这样 fn test>(path: P) { path.join("13123123"); } 当我编译它时,它给了我以下错误 error[E05
我是一名优秀的程序员,十分优秀!