go语言提供了一种机制,在不知道具体类型的情况下,可以用反射来更新变量值,查看变量类型
typeof
typeof返回接口中保存的值得类型,typeof(nil)会返回nil
实例
package main
import (
"fmt"
"reflect"
)
func main() {
var booknum float32 = 6
var isbook bool = true
bookauthor := "www.coonote.cn"
bookdetail := make(map[string]string)
bookdetail["go语言教程"]="www.coonote.cn"
fmt.println(reflect.typeof(booknum))
fmt.println(reflect.typeof(isbook))
fmt.println(reflect.typeof(bookauthor))
fmt.println(reflect.typeof(bookdetail))
}
以上代码执行结果如下
float32
bool
string
map[string]string
valueof
valueof返回一个初始化为interface接口保管的具体值得value,valueof(nil)返回value零值
通过反射获取值
实例
package main
import (
"fmt"
"reflect"
)
func main() {
var booknum float32 = 6
var isbook bool = true
bookauthor := "www.coonote.cn"
bookdetail := make(map[string]string)
bookdetail["go语言教程"]="www.coonote.cn"
fmt.println(reflect.valueof(booknum))
fmt.println(reflect.valueof(isbook))
fmt.println(reflect.valueof(bookauthor))
fmt.println(reflect.valueof(bookdetail))
}
以上代码执行结果如下
6
true
www.coonote.cn
map[go语言教程:www.coonote.cn]
通过反射设置值
package main
import (
"fmt"
"reflect"
)
func reflectsetvalue1(x interface{}){
value:=reflect.valueof(x)
if value.kind() == reflect.string{
value.setstring("欢迎来到coonote")
}
}
func reflectsetvalue2(x interface{}){
value:=reflect.valueof(x)
// 反射中使用elem()方法获取指针所指向的值
if value.elem().kind() == reflect.string{
value.elem().setstring("欢迎来到coonote")
}
}
func main() {
address := "www.coonote.cn"
// reflectsetvalue1(address)
// 反射修改值必须通过传递变量地址来修改。若函数传递的参数是值拷贝,则会发生下述错误。
// panic: reflect: reflect.value.setstring using unaddressable value
reflectsetvalue2(&address)
fmt.println(address)
}
以上代码执行结果如下
欢迎来到coonote
使用建议
1、大量使用反射的代码通常会变得难以理解
2、反射的性能低下,基于反射的代码会比正常的代码运行速度慢一到两个数量级