golang reflect
go blog随笔
- 最近看go blog, 发现go升级到1.7了,最大的改进是编译的二进制文件缩小了近30%.
- 那么这30%是怎么来的呢,什么特征使其压缩了文件大小:
- ssa (Static Single Assignment,静态单赋值) 编译方法,压缩5%
- method pruning 方法修剪,压缩15%
- compact format 更合适的格式, 压缩5-15%
其中method prying 和compact format都涉及到了reflect包。那接下来我们就说说golang 的reflect吧。
reflection是基于类型系统(type system)的, 而go语言是静态类型的,因而每个变量都有一个静态类型(即确定的并且编译时固定的类型),int, []byte, float32, *MyType等等。
如果我们声明
```
type MyInt int
var i int
var j MyInt
```
那么i是int类型,j是MyInt类型,i和j拥有不同的静态类型,尽管他们的基础类型(underlying type)一致,不经过类型转换也不能直接赋值。
type一个重要的分类是interface types,其实意思就是接口也是go的一种类型。
空的接口类型为:interface{}
reflection法则:
1. reflection goes from interface value to reflection object
reflect包含有两个类型,Type和Value, 以及经常用到的2个简单的方法reflect.Typeof(), reflect.Valueof, 解析了interface中的类型和值。
```
var x float64 = 3.4
fmt.Println("type", reflect.TypeOf(x))
```
打印:type: float64
2. reflection goes from reflection object to interface value
3. to modify a reflection object, the value must be settable
可不可以设置是由reflection object 是否holds原始信息决定的。
----------------------------------------------------------------------------
deep equal:以前写utest的时候,比较map,只能比较各长度,现在有了reflect.DeepEqual,终于可以深度比较了。
a := map[int]string{1: "hello", 2: "hi"}
b := map[int]string{2:"hi", 1:"hello"}
fmt.Println("deep equal", reflect.DeepEqual(a, b))
答案是true
----------------------------------------------------------------------------
golang的bytes包跟strings包一样强大,strings包有的方法,bytes包基本上都有额。bytes.Join, bytes.HasPrefix, bytes.LastIndex, bytes.Split……跪拜了。
有疑问加站长微信联系(非本文作者)