go errors转string

摘要:
如果在Go中声明了两个具有相同字符的错误,但名称是一个新变量,则这两个错误不等于packagemainimport(“errors”“fmt”)varerr1=errors。New(“not found”)varerr2=errors。New(“not found”)funcmain(){fmt.Println(err1)fmt.PrintIn(err2)ifer1==err2{fmt.Println
前言

在 Go 中如果声明了两个字符相同的错误,但命名是新的变量,此时两个错误不相等

package main

import (
	"errors"
	"fmt"
)

var err1 = errors.New("not found")
var err2 = errors.New("not found")

func main()  {

	fmt.Println(err1)
	fmt.Println(err2)

	if err1 == err2 {
		fmt.Println("这两个错误相同")
	} else {
		fmt.Println("这两个错误不相同")
	}
}

输出

not found
not found
这两个错误不相同

那么如何比较两个这两个错误呢?这个应用场景在于不同包定义了相同的错误,这时候想要进行错误对比

解答

error 实现了 error 接口,所以我们可以使用 err.Error() 方法来转换 string,进行对比字符串值

type error interface {
	Error() string
}
package main

import (
	"errors"
	"fmt"
)

var err1 = errors.New("not found")
var err2 = errors.New("not found")

func main()  {

	fmt.Println(err1.Error())
	fmt.Println(err2.Error())

	if err1.Error() == err2.Error() {
		fmt.Println("这两个错误相同")
	} else {
		fmt.Println("这两个错误不相同")
	}
}

输出

not found
not found
这两个错误相同

免责声明:文章转载自《go errors转string》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇RabbitMQ消息队列gdal_merge.py下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

mysql主从不同步问题 Error_code: 1197

首先查看从的状态 mysql> show slave status G *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event...

Python 2.75升级3.6.3

https://blog.csdn.net/wwwdaan5com/article/details/78218277 Centos 7 默认yum安装python 是2.7.5, (网上看了很多升级都是错的 导致python混乱,导致yum坏了,本人还重装了yum:http://www.cnblogs.com/eason-d/p/8608180.html)...

Let's GO(三)

人生苦短,Let's GO Let's GO(一) Let's GO(二) Let's GO(三) Let's GO(四) 今天我学了什么? 1. 结构体(struct) /* type TYPENAME struct { name type ... } */ type person struct { name, city string //这里...

MySQL服务器端&客户端常见错误

目录(?)[+] 客户端 服务器端 客户端 1.ERROR 2013 (HY000) at line 1: Lost connection to MySQL server during query 使用select 一个大表,query的过程中被主库kill掉会出现下面错误 2.ERROR 2006 (HY000): MySQL...

SQL Server 2008 远程过程调用失败

今天在写程序的时候,突然间发现数据库连接不上了,打开管理器发现SQL2008出现这样的错误。 非常的郁闷,找了好多方法都没有解决,最后想想是不是应为安装vs2013中的SQL Server Express LocalDB的问题呢,于是把这个卸载掉,重新的打开管理器居然可以用了,然后马上重启服务,可以服务却启动失败了,原因是:1069,由于登陆失败而无法启...

CDH部署日志

CDH部署时出现如图所示的错误 可去服务器查看:/opt/cm-5.5.0/run/cloudera-scm-agent/process/ccdeploy_hbase-conf_etchbaseconf.cloudera.hbase_4827987947391625860 日志 根据日志解决。 /var/lib/alternatives...