浅谈Go语言反射

简介: 浅谈Go语言反射

1 为什么需要反射

反射是框架的灵魂。

反射(Reflection)其实是通过允许在运行时存取程序数据,以改变程序行为的程序设计技术。也就是说,反射可以帮助我们将动态的功能实现或调用变为静态的功能描述。

反射有优点就是可以让程序灵活,更新和维护都更加简单方便,但是反射并不是没有缺点,反射在执行时对于CPU和内存资源会进行占用。

2 Go反射的使用

2.1 针对结构体的反射
type Student struct {
   Id   int64
   Name string
   Age  int
}
func TestStruct(t *testing.T) {
  stu := Student{1, "zs", 12}
  obj := reflect.ValueOf(stu)
  field := obj.FieldByName("Name")
  field1 := obj.Field(0)
  num := obj.NumField()
  fmt.Println("字段数量:", num)
  fmt.Println("Name字段的值:", field)
  fmt.Println("第0个字段的值:", field1)
  obj1 := reflect.ValueOf(new(Student))
  addr := obj1.CanAddr() //是否能寻址
  if addr {
    fmt.Println(obj1.Addr())
  }
}
2.2 针对常见数据结构的反射
// 切片类型的反射
func TestSlice(t *testing.T) {
  slice := make([]int, 10)
  s := reflect.ValueOf(slice)
  //加入元素
  s.Index(0).Set(reflect.ValueOf(100))
  //获取元素
  i := s.Index(0).Interface()
  fmt.Println(slice)
  fmt.Println(i)
}
// Map类型的反射
func TestMap(t *testing.T) {
  m := make(map[string]interface{})
  m["A"] = 1
  m["B"] = 2
  m["C"] = 3
  mv := reflect.ValueOf(m)
  //赋值
  mv.SetMapIndex(reflect.ValueOf("D"),reflect.ValueOf(4))
  iter := mv.MapRange()
  keys := mv.MapKeys()
  fmt.Println(keys)
  for iter.Next() {
    fmt.Println(iter.Value())
  }
}

3 小总结

反射在架构中扮演者很重要的作用,其中最重要的就是增强架构的抽象,Go语言反射里最重要的两个概念是Type和Value,Type用于获取类型相关的信息(比如slice的长度,Struct的成员,函数的参数),Value用于获取和修改原始数据的值(比如修改slice和map中的元素,修改Struct的成员变量)。

参考:

https://zhuanlan.zhihu.com/p/411313885

相关文章
|
6月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
343 2
|
编译器 Go
揭秘 Go 语言中空结构体的强大用法
Go 语言中的空结构体 `struct{}` 不包含任何字段,不占用内存空间。它在实际编程中有多种典型用法:1) 结合 map 实现集合(set)类型;2) 与 channel 搭配用于信号通知;3) 申请超大容量的 Slice 和 Array 以节省内存;4) 作为接口实现时明确表示不关注值。此外,需要注意的是,空结构体作为字段时可能会因内存对齐原因占用额外空间。建议将空结构体放在外层结构体的第一个字段以优化内存使用。
|
运维 监控 算法
监控局域网其他电脑:Go 语言迪杰斯特拉算法的高效应用
在信息化时代,监控局域网成为网络管理与安全防护的关键需求。本文探讨了迪杰斯特拉(Dijkstra)算法在监控局域网中的应用,通过计算最短路径优化数据传输和故障检测。文中提供了使用Go语言实现的代码例程,展示了如何高效地进行网络监控,确保局域网的稳定运行和数据安全。迪杰斯特拉算法能减少传输延迟和带宽消耗,及时发现并处理网络故障,适用于复杂网络环境下的管理和维护。
|
8月前
|
Cloud Native 安全 Java
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
516 1
|
8月前
|
Cloud Native Go API
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
544 0
|
8月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
370 0
|
8月前
|
Cloud Native Java 中间件
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
421 0
|
8月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
464 0
|
8月前
|
数据采集 Go API
Go语言实战案例:多协程并发下载网页内容
本文是《Go语言100个实战案例 · 网络与并发篇》第6篇,讲解如何使用 Goroutine 和 Channel 实现多协程并发抓取网页内容,提升网络请求效率。通过实战掌握高并发编程技巧,构建爬虫、内容聚合器等工具,涵盖 WaitGroup、超时控制、错误处理等核心知识点。
|
10月前
|
JSON 编解码 API
Go语言网络编程:使用 net/http 构建 RESTful API
本章介绍如何使用 Go 语言的 `net/http` 标准库构建 RESTful API。内容涵盖 RESTful API 的基本概念及规范,包括 GET、POST、PUT 和 DELETE 方法的实现。通过定义用户数据结构和模拟数据库,逐步实现获取用户列表、创建用户、更新用户、删除用户的 HTTP 路由处理函数。同时提供辅助函数用于路径参数解析,并展示如何设置路由器启动服务。最后通过 curl 或 Postman 测试接口功能。章节总结了路由分发、JSON 编解码、方法区分、并发安全管理和路径参数解析等关键点,为更复杂需求推荐第三方框架如 Gin、Echo 和 Chi。

热门文章

最新文章

下一篇
开通oss服务