博客
关于我
Go语言如何判断是否是零值
阅读量:430 次
发布时间:2019-03-06

本文共 629 字,大约阅读时间需要 2 分钟。

通过封装IsZeroOfUnderlyingType方法判断,代码如下

package mainimport (	"fmt"	"reflect")type Person struct {	Name string	Age  int}func IsZeroOfUnderlyingType(x interface{}) bool {	return reflect.DeepEqual(x, reflect.Zero(reflect.TypeOf(x)).Interface())}func main() {	var person Person //定义一个零值	fmt.Println(IsZeroOfUnderlyingType(person)) //零值结构体,输出true	person.Name = "chenqiognhe"                 //结构体属性Name赋值	fmt.Println(IsZeroOfUnderlyingType(person)) //输出false	fmt.Println(IsZeroOfUnderlyingType(person.Age)) //Age仍是零值,输出true	person.Age = 18                                 //Age赋值	fmt.Println(IsZeroOfUnderlyingType(person.Age)) //输出false}

转载地址:http://uwlkz.baihongyu.com/

你可能感兴趣的文章
MySQL里的那些日志们
查看>>
mysql重新安装?忘记root密码?重装Windows、Linux系统导致mysql没法用吗? 这里有你想要的答案
查看>>
mysql重置root密码
查看>>
MySQL锁
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
MySQL锁机制
查看>>
mysql锁机制,主从复制
查看>>
Mysql锁机制,行锁表锁
查看>>
MySQL锁表问题排查
查看>>
Mysql锁(1):锁概述和全局锁的介绍
查看>>
Mysql锁(2):表级锁
查看>>
MySQL锁,锁的到底是什么?
查看>>
MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案
查看>>
Mysql错误2003 -Can't connect toMySQL server on 'localhost'(10061)解决办法
查看>>
MySQL错误提示mysql Statement violates GTID consistency
查看>>
mysql错误:This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de
查看>>
mysql长事务
查看>>
mysql问题记录
查看>>
mysql间隙锁
查看>>
MySQL集群解决方案(1):MySQL数据库的集群方案
查看>>