一、概述
在golang中会涉及变量(var声明)、常量(const)、枚举(golang从语法上没有enum的定义,可以使用iota来实现)、基本类型、引用类型(slice、map、channel)、类型转换、自定义类型、未命名类型等内容,不过很多是和大家熟知的Java、C#中概念差不多,只是具体存在一些差异,不过需要记住一点golang是静态类型语言,其对应的变量总有固定的数据类型,其类型也决定变量内存的长度和储存格式,也意味着只能更改其变量值而不能变更其类型。
二、具体实例
package main
import (
"reflect"
"unsafe"
)
func main() {
type data int
var d data = 10
// var x int = d // 该操作是不会进行隐式转换的
var x int = int(d)
println(x)
//println(d == x) // 该操作是不被允许的
// 具有相同元素类型和长度的数组 即认为是同一类型
aa := [10]int{}
bb := [10]int{}
println(aa == bb)
// 具有相同基类型的指针 即认为是同一类型
aaa := unsafe.Pointer(uintptr(1))
bbb := unsafe.Pointer(uintptr(1))
println(aaa == bbb)
// 具有相同元素类型的切片 可认为是相同的切片; 比较需要使用reflect.DeepEqual来完成
aslice := make([]int, 0, 10)
bslice := make([]int, 0, 10)
// bslice := make([]int, 1, 10) // 当给定slice的length不相同时 也不会认为两个slice是相同的;不同的容量值却不影响
println(reflect.DeepEqual(aslice,bslice))
// 具有相同的键值类型的map 即认为是相同的map; 比较需要使用reflect.DeepEqual来完成:故使用别名和新建类型都不影响最终的结果
amap := make(map[string]int)
bmap := make(map[string]int)
println(reflect.DeepEqual(amap, bmap))
type MyInt = int // 使用golang的别名:
cmap := make(map[string]int)
println(reflect.DeepEqual(amap, cmap))
type MyInt1 int // 使用golang自定义类型
dmap := make(map[string]int)
println(reflect.DeepEqual(amap, dmap))
// 具有相同数据类型及操作方向的channel 即认为是相同类型
//cc := make(chan int)
var achan (<-chan int)
var bchan (<-chan int)
println(reflect.DeepEqual(achan, bchan))
var cchan (chan <-int)
//var dchan (chan <-int)
var dchan (chan <-MyInt)
//println((cchan == dchan))
println(reflect.DeepEqual(cchan, dchan))
// 属于相同类型的channel必须满足数据类型和操作方向:下面的两个双向channel是不相同的
echan := make(chan int)
fchan := make(chan int)
println(reflect.DeepEqual(echan, fchan))
// 具有相同字段名及类型、标签、字段顺序的struct可认为是相同的
astruct := struct {
name string
age int
}{}
bstruct := struct {
name string
age int
}{}
//println(astruct == bstruct)
println(reflect.DeepEqual(astruct, bstruct))
// 具有相同签名(参数和返回值列表,不含参数名)的函数可认为是相同的
var afunc func(i int) int
var bfunc func(i int) int
println(reflect.DeepEqual(afunc, bfunc))
var cfunc func(i MyInt) int
var dfunc func(a int) int
println(reflect.DeepEqual(cfunc, dfunc))
// 具有相同方法集(方法名及签名,不含顺序)的interface可认为是相同的
var ainter interface{
helloWorld(name string) string
test1()
}
var binter interface{
test1()
helloWorld(name string) string
}
println(reflect.DeepEqual(ainter, binter))
}
//
// 即使不同的自定义类型指定的基础类型具有相同底层数据结构,也不能认为基础类型之间存在任何关系,两者属于不同的类型
// 自定义类型之间并不会继承基础类型的信息
// *** 对应的自定义类型不能被视为别名Alices ; 不能隐式转换; 不能直接用于比较表达式
// reflect.DeepEqual是基于底层数据类型来进行比较的
//
有疑问加站长微信联系(非本文作者)