我试图在 GO 中创建错误的子类型。
现在我面临着多种类型的问题。以下代码显示了错误类型定义:
/* Interfaces */
type UniversalError interface {
CommonError1
}
type CommonError1 interface {
error
CommonError1()
}
/* Structs */
type Error1 struct {
reason string
}
type Error2 struct {
reason string
}
type Error3 struct {
reason string
}
/* Interface function implementations */
func (error1 Error1) Error() string {
return fmt.Sprintf(error1.reason)
}
func (error2 Error2) Error() string {
return fmt.Sprintf(error2.reason)
}
func (error3 Error3) Error() string {
return fmt.Sprintf(error3.reason)
}
func (Error1) CommonError1() {}
func (Error2) CommonError1() {}
func (Error3) UniversalError() {}
当我尝试运行以下代码时:
func main() {
var err1 = Error1{reason: "Error reason 1"}
var err2 = Error2{reason: "Error reason 2"}
var err3 = Error3{reason: "Error reason 3"}
fmt.Println("\n**** Types *****")
printType(err1)
printType(err2)
printType(err3)
}
func printType(param error) {
switch param.(type) {
case UniversalError:
switch param.(type) {
case CommonError1:
switch param.(type) {
case Error1:
fmt.Println("Error1 found")
case Error2:
fmt.Println("Error2 found")
default:
fmt.Println("CommonError1 found, but Does not belong to Error1 or Error2")
}
default:
fmt.Println("Error3 Found")
}
default:
fmt.Println("Error belongs to an unidentified type")
}
}
该printType()函数打印以下内容:
**** Types *****
Error1 found
Error2 found
CommonError1 found, but Does not belong to Error1 or Error2
我需要将 的类型Error3识别为 an UniversalError,而不是 a CommonError1。我怎样才能做到这一点?我的做法有什么问题吗?
HUH函数
相关分类