2 回答

TA贡献1921条经验 获得超9个赞
https://golang.org/pkg/net/#Error是一个接口,并且定义Timeout并且Temporary将是微不足道的,因为它们只是返回bool。
package main
import(
"fmt"
"net"
)
type mockNetError struct {
temporary bool
timeout bool
}
func (e *mockNetError)Error() string {
return fmt.Sprintf("mockNetworkError: timeout %b, temporary %b", e.timeout, e.temporary)
}
func (e *mockNetError)Temporary() bool{
return e.temporary
}
func (e *mockNetError)Timeout() bool{
return e.timeout
}
func main() {
var err error = new(mockNetError)
if nerr, ok := err.(net.Error); ok {
fmt.Println("It was a network error! %s", nerr.Error())
}
}
但是,因为net.Error是接口类型,err.(type)所以永远不会返回它。在我的代码中,我断言它可能满足该接口,这与询问它是否是err接口中值的类型不同。
您提到的其他错误net不是接口(尽管它们确实满足net.Error)。
https://blog.golang.org/go1.13-errors讨论了错误包装在 go 中的工作原理。
约定而不是更改:包含另一个错误的错误可能会实现返回底层错误的 Unwrap 方法。
原因%w几乎总是这样做的,因为人们几乎总是在错误中添加额外的文本。
实际上,是一个可以通过提供方法net.OsError包装另一个错误的示例。Unwrap()
如果您想创建这样的错误,只需:
fmt.Println(net.OpError{
Op: "mock",
Net: "mock",
Source: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 1234 },
Addr: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 12340 },
Err: fmt.Errorf("Mock net.OpError"),
})

TA贡献1804条经验 获得超7个赞
基于 Daniel Farrell 的回答,我发现了一个模拟 os.SyscallError 的示例,该示例深埋在适用于 Golang 的 AWS 开发工具包中。把它们放在一起,我们得到这个:
return nil, &net.OpError{ Op: "mock", Net: "mock", Source: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 1234}, Addr: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 12340}, Err: &os.SyscallError{Syscall: "read", Err: syscall.ECONNRESET}, }
- 2 回答
- 0 关注
- 105 浏览
添加回答
举报