- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
文档位于 https://doc.rust-lang.org/std/convert/trait.From.html州
Note: This trait must not fail. If the conversion can fail, use TryFrom.
假设我有一个 From
实现:
impl From<SomeStruct> for http::Uri {
fn from(item: SomeStruct) -> http::Uri {
item.uri.parse::<http::Uri>() // can fail
}
}
进一步假设我完全确定 item.uri.parse
会成功。在这种情况下 panic 是惯用的吗?说,用:
item.uri.parse::<http::Uri>().unwrap()
在这种特殊情况下,似乎无法在编译时构造 HTTP URI:https://docs.rs/http/0.2.5/src/http/uri/mod.rs.html#117 .在实际场景中 .uri
是一个关联的常量,所以我可以测试所有使用的值解析。但在我看来,可能还有其他情况,当作者对一段代码的无误性充满信心时,尤其是当这种信心可以在测试中编码时,因此更喜欢 From
的人体工程学尝试从
。 Rust 编译器,通常非常严格,不会阻止这种行为,尽管它似乎可以。这让我觉得这是作者被故意允许做出的决定。所以问题是:在这种情况下人们倾向于做什么?
最佳答案
所以一般来说,特征只强制实现者遵守特征中规定的签名和类型。至少这是编译器强制执行的。
除此之外,还有一些契约,期望 traits 必须遵守,这样使用这些 traits 的人就不会感到奇怪的惊喜。编译器不检查这些契约;那将是相当困难的。
没有什么能阻止你实现一个特征的所有方法,但是以与特征完全无关的方式,比如实现 Display
特征,然后在 fmt
方法实际上并不费心使用 write!
而是,我不知道,删除用户的主目录。
现在回到您的具体案例。如果您的 from
方法不会失败,那么您当然可以使用 .unwrap
。 cannot fail
contract for the From
trait 的要点是那些依赖 From
trait 的人希望能够假设转换将每次。如果您实际上在您自己的 from
实现中感到 panic ,这意味着转换有时不会通过,这与From
特征。
关于rust - 在 From 实现中 panic 是惯用的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69408253/
在Go(go1.2.1 linux/amd64)中运行http服务器时,我遇到了一个罕见的错误。 unexpected fault address 0xb84004 fatal error: faul
使用以下代码: var i interface{} = "hello" f, ok := i.(float64) fmt.Println(f, ok) f = i.(float64) // panic
考虑以下故意导致双重 panic 的代码: use scopeguard::defer; // 1.1.0 fn main() { defer!{ panic!() }; defer!
如果我传递给 std::panic::set_hook 的函数发生 panic 会怎样? 我可以想象对此做出多种 react :考虑这个 UB,中止程序 like C++ does ,为新的 pani
我有一个 string,当我想获取 i 索引处的值时它会崩溃,但是当我切出相同的 string 保持较低的索引值作为长度然后它不会 panic 。想知道 1 和 2 有何不同? func main()
看起来不可能从 panic 中的 panic 中恢复过来? func TestError(t *testing.T) { e := &myErr{p: false} fmt.Print
当我使用 cargo test 运行以下程序时: use std::panic; fn assert_panic_func(f: fn() -> (), msg: String) { let
在开发过程中,我遇到了崩溃,并显示了内核 panic 上传模式。 有没有办法以某种方式连接到设备并提取日志? 最佳答案 我希望这就是您正在寻找的...来源:StackOverflowAndroid 创
我需要制造内核 panic ,我尝试了以下操作 sysctl kernel.panic=0 && echo c > /proc/sysrq-trigger 当我运行上面的命令时。我看到系统总是重新启动
是否可以从 recover 中“重新抛出”错误并保留原始堆栈跟踪?我知道的最好的办法就是再次 panic ,但这确实会创建一个新的堆栈跟踪。 func do() { defer func()
我正在使用 panic::catch_unwind引起 panic : use std::panic; fn main() { let result = panic::catch_unwind
func sub(){ defer func (){ panic(2) }() panic(1) } func main(){ defer func()
考虑到我使用的是原始的“errors”go 包。 还有,panic(11) 和 panic("11") 之间的区别? 最佳答案 panic定义为 func panic(v interface{}),调
我是 golang 的新手。在定义位置后 try catch 主 block 中的错误后,我的程序出现 panic 。我在某处读过,添加 defer.close() 可能会有所帮助,但编译器再次说你的
有这种新的编程语言 V-lang由亚历克斯·梅德维尼科夫 (Alex Medvednikov) 创建。我目前使用的是 V-lang 0.1.11 版。我可以在 V-lang 中声明一个数组,如下所示:
在启动 linux 时,我在控制台上得到以下打印,并且系统挂起。 Waiting for root device /dev/mmcblk0p2... mmc_host mmc0: Bus speed
我已经实现了这个 answer 中提到的 goroutine 的生产者-消费者模式.但它有时会出现 panic ,并出现错误提示:“ panic :同步:负 WaitGroup 计数器”。我有如下示例
上下文: https://github.com/fusspawn/tserver/blob/master/app/controllers/gorp.go 作为尝试设置 gorm 的一部分,我尝试转换标
专注Golang,Python语言,云原生,人工智能领域得博主 过去经历的意义在于引导你,而非定义你, 只要我们足够努力,任何人都有无限潜力 panic 抛出异常函数 recove
这个问题在这里已经有了答案: How to return a value in a Go function that panics? (3 个回答) 2年前关闭。 package main impor
我是一名优秀的程序员,十分优秀!