- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Go语言基础反射示例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在程序运行期对程序动态的进行访问和修改 。
reflect godoc: https://golang.org/pkg/reflect/ 。
reflect包有两个数据类型:
Type:数据类型 【reflect.TypeOf():是获取Type的方法】 。
Value:值的类型【reflect.ValueOf():是获取Value的方法】 。
获取变量类型 。
1
|
func TypeOf(i interface{}) Type //Type是interface{}的别名
|
例子 。
1
2
|
reflect.TypeOf(10) //int
reflect.TypeOf(struct{ age int }{10}) //struct { age int }
|
获取变量的种类 。
1
2
|
reflect.TypeOf(struct{ age int }{10}).Kind() //reflect.Struct
reflect.ValueOf("hello word").Kind() //reflect.String
|
获取变量值 。
1
|
func ValueOf(i interface{}) Value //value是struct {}别名
|
例子 。
1
2
|
reflect.ValueOf("hello word") //hello word
reflect.ValueOf(struct{ age int }{10}) //{10}
|
修改普通类型 。
1
2
|
str := "hello word"
reflect.ValueOf(&str).Elem().SetString("张三")
|
修改结构体 。
1
2
3
4
|
//第一步:ValueOf():传入一个变量的地址,返回是变量的地址 Elem():返回的是变量的原始值
elem:=reflect.ValueOf(&变量名).Elem()
//第二步 FieldByName():传入结构体字段名称 SetString():传入你要修改的变量值
elem.FieldByName("Name").SetString("李四")
|
1
2
3
4
5
6
7
8
9
10
11
|
//定义一个User结构体
type User struct {
Name string
Age int
}
user := User{Name: "张三", Age: 10}
//Elem() 获取user原始的值
elem := reflect.ValueOf(&user).Elem()
//FieldByName() 通过Name返回具有给定名称的结构字段 通过SetString 修改原始的值
elem.FieldByName("Name").SetString("李四")
elem.FieldByName("Age").SetInt(18)
|
无参方法 。
1
2
3
|
//MethodByName():传方法名,方法名必须大小 Call():方法的形参
reflect.ValueOf(变量名).MethodByName(方法名).Call([]reflect.Value{})
reflect.ValueOf(变量名).MethodByName(方法名).Call(make([]reflect.Value, 0))
|
1
2
3
4
5
6
7
8
9
10
|
type User struct {
Name string `json:"name" name:"张三"`
Age int
}
func (_ User) Say() {
fmt.Println("user 说话")
}
user := User{Name: "张三", Age: 10}
reflect.ValueOf(&user).MethodByName("Say").Call([]reflect.Value{})
reflect.ValueOf(user).MethodByName("Say").Call(make([]reflect.Value, 0))
|
有参方法 。
1
|
reflect.ValueOf(变量名).MethodByName(方法名).Call([]reflect.Value{reflect.ValueOf("该说话了"), reflect.ValueOf(1)})
|
1
2
3
4
5
6
7
8
9
|
type User struct {
Name string `json:"name" name:"张三"`
Age int
}
func (_ User) Say() {
fmt.Println("user 说话")
}
user := User{Name: "张三", Age: 10}
reflect.ValueOf(user).MethodByName("SayContent").Call([]reflect.Value{reflect.ValueOf("该说话了"), reflect.ValueOf(1)})
|
反射调用struct的方法必须是公有的 。
反射调用无参方法时必修传 nil 或者 []reflect.Value{} 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
package main
import (
"fmt"
"reflect"
)
func main() {
//1. 获取变量类型
fmt.Println("获取变量类型")
fmt.Println(reflect.TypeOf(10)) //int
fmt.Println(reflect.TypeOf(10.0)) //float64
fmt.Println(reflect.TypeOf(struct{ age int }{10})) //struct { age int }
fmt.Println(reflect.TypeOf(map[string]string{"a": "a"})) //map[string]string
fmt.Println("")
//2. 获取变量值
fmt.Println("获取变量值")
fmt.Println(reflect.ValueOf("hello word")) //hello word
fmt.Println(reflect.ValueOf(struct{ age int }{10})) //{10}
fmt.Println(reflect.TypeOf(struct{ age int }{10}).Kind()) //struct
//类型判断
if t := reflect.TypeOf(struct{ age int }{10}).Kind(); t == reflect.Struct {
fmt.Println("是结构体")
} else {
fmt.Println("不是结构体")
}
//修改目标对象
str := "hello word"
//普通变量修改
reflect.ValueOf(&str).Elem().SetString("张三")
fmt.Println(str)
//结构体变量修改
user := User{Name: "张三", Age: 10}
//Elem() 获取user原始的值
elem := reflect.ValueOf(&user).Elem()
//FieldByName() 通过Name返回具有给定名称的结构字段 通过SetString 修改原始的值
elem.FieldByName("Name").SetString("李四")
elem.FieldByName("Age").SetInt(18)
fmt.Println(user)
//获取结构体的标签的值
fmt.Println(reflect.TypeOf(&user).Elem().Field(0).Tag.Get("name"))
//调用无参方法
reflect.ValueOf(&user).MethodByName("Say").Call([]reflect.Value{})
reflect.ValueOf(user).MethodByName("Say").Call(make([]reflect.Value, 0))
//调用有参方法
reflect.ValueOf(user).MethodByName("SayContent").Call([]reflect.Value{reflect.ValueOf("该说话了"), reflect.ValueOf(1)})
//调用本地的方法
reflect.ValueOf(Hello).Call([]reflect.Value{})
reflect.ValueOf(Hello).Call(nil)
fmt.Printf("%#v\n", reflect.TypeOf(user).Field(0))
}
func Hello() {
fmt.Println("hello")
}
type Person struct {
Name string
}
type User struct {
Person // //反射会将匿名字段作为一个独立字段来处理
Name string `json:"name" name:"张三"`
Age int
}
func (_ User) Say() {
fmt.Println("user 说话")
}
func (_ User) SayContent(content string, a int) {
fmt.Println("user", content, a)
}
|
以上就是Go语言基础反射示例详解的详细内容,更多关于Go语言反射的资料请关注我其它相关文章! 。
原文链接:https://blog.csdn.net/guofeng93/article/details/92678665 。
最后此篇关于Go语言基础反射示例详解的文章就讲到这里了,如果你想了解更多关于Go语言基础反射示例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
大家好,我是汤师爷~ 什么是订单履约系统? 订单履约是从消费者下单支付到收到商品的全流程管理过程,包括订单接收、订单派单、库存分配、仓储管理和物流配送等环节,核心目标是确保商品准时、准确地送达消费
大家好,我是汤师爷~ 今天聊聊促销系统整体规划。 各类促销活动的系统流程,可以抽象为3大阶段: B端促销活动管理:商家运营人员在后台系统中配置和管理促销活动,包括设定活动基本信息、使用规则
全称“Java Virtual Machine statistics monitoring tool”(statistics 统计;monitoring 监控;tool 工具) 用于监控虚拟机的各种运
主要是讲下Mongodb的索引的查看、创建、删除、类型说明,还有就是Explain执行计划的解释说明。 可以转载,但请注明出处。  
1>单线程或者单进程 相当于短链接,当accept之后,就开始数据的接收和数据的发送,不接受新的连接,即一个server,一个client 不存在并发。 2>循环服务器和并发服务器
详解 linux中的关机和重启命令 一 shutdown命令 shutdown [选项] 时间 选项: ?
首先,将json串转为一个JObject对象: ? 1
matplotlib官网 matplotlib库默认英文字体 添加黑体(‘SimHei')为绘图字体 代码: plt.rcParams['font.sans-serif']=['SimHei'
在并发编程中,synchronized关键字是常出现的角色。之前我们都称呼synchronized关键字为重量锁,但是在jdk1.6中对synchronized进行了优化,引入了偏向锁、轻量锁。本篇
一般我们的项目中会使用1到2个数据库连接配置,同程艺龙的数据库连接配置被收拢到统一的配置中心,由DBA统一配置和维护,业务方通过某个字符串配置拿到的是Connection对象。  
实例如下: ? 1
1. MemoryCahe NetCore中的缓存和System.Runtime.Caching很相似,但是在功能上做了增强,缓存的key支持object类型;提供了泛型支持;可以读缓存和单个缓存
argument是javascript中函数的一个特殊参数,例如下文,利用argument访问函数参数,判断函数是否执行 复制代码 代码如下: <script
一不小心装了一个Redis服务,开了一个全网的默认端口,一开始以为这台服务器没有公网ip,结果发现之后悔之莫及啊 某天发现cpu load高的出奇,发现一个minerd进程 占了大量cpu,googl
今天写这个是为了 提醒自己 编程过程 不仅要有逻辑 思想 还有要规范 代码 这样可读性 1、PHP 编程规范与编码习惯最主要的有以下几点: 1 文件说明 2 funct
摘要:虚拟机安装时一般都采用最小化安装,默认没有lspci工具。一台测试虚拟网卡性能的虚拟机,需要lspci工具来查看网卡的类型。本文描述了在一个虚拟机中安装lspci工具的具体步骤。 由于要测试
1、修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进行高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量的限制(这是因为系统
目录 算术运算符 基本四则运算符 增量赋值运算符 自增/自减运算符 关系运算符 逻
如下所示: ? 1
MapperScannerConfigurer之sqlSessionFactory注入方式讲解 首先,Mybatis中的有一段配置非常方便,省去我们去写DaoImpl(Dao层实现类)的时间,这个
我是一名优秀的程序员,十分优秀!