Go 语言从入门到实战
蔡超
Mobvista 技术副总裁兼首席架构师,前亚马逊(中国)首席软件架构师
48919 人已学习
新⼈⾸单¥59
课程目录
已完结/共 55 讲
第一章:Go语言简介 (4讲)
第二章:基本程序结构 (4讲)
第三章:常用集合 (3讲)
第四章:字符串 (1讲)
时长 16:47
第五章:函数 (2讲)
第六章:面向对象编程 (4讲)
第七章:编写好的错误处理 (2讲)
第八章:包和依赖管理 (2讲)
第九章:并发编程 (7讲)
第十章:典型并发任务 (5讲)
第十一章:测试 (3讲)
时长 11:48
时长 07:12
时长 06:15
第十二章:反射和Unsafe (3讲)
时长 08:18
时长 08:03
第十三章:常见架构模式的实现 (2讲)
第十四章:常见任务 (4讲)
时长 04:27
时长 05:14
第十五章:性能调优 (4讲)
第十六章:高可用性服务设计 (5讲)
Go 语言从入门到实战
登录|注册
留言
10
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 38 | 反射编程
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | Go语言课程介绍
02 | 内容综述
03 | Go语言简介:历史背景、发展现状及语言特性
04 | 编写第一个Go程序
05 | 变量、常量以及与其他语言的差异
06 | 数据类型
07 | 运算符
08 | 条件和循环
09 | 数组和切片
10 | Map声明、元素访问及遍历
11 | Map与工厂模式,在Go语言中实现Set
12 | 字符串
13 | Go语言的函数
14 | 可变参数和defer
15 | 行为的定义和实现
16 | Go语言的相关接口
17 | 扩展与复用
18 | 不一样的接口类型,一样的多态
19 | 编写好的错误处理
20 | panic和recover
21 | 构建可复用的模块(包)
22 | 依赖管理
23 | 协程机制
24 | 共享内存并发机制
25 | CSP并发机制
26 | 多路选择和超时
27 | channel的关闭和广播
28 | 任务的取消
29 | Context与任务取消
30 | 只运行一次
31 | 仅需任意任务完成
32 | 所有任务完成
33 | 对象池
34 | sync.pool对象缓存
35 | 单元测试
36 | Benchmark
37 | BDD
38 | 反射编程
39 | 万能程序
40 | 不安全编程
41 | 实现pipe-filter framework
42 | 实现micro-kernel framework
43 | 内置JSON解析
44 | easyjson
45 | HTTP服务
46 | 构建RESTful服务
47 | 性能分析工具
48 | 性能调优示例
49 | 别让性能被锁住
50 | GC友好的代码
51 | 高效字符串连接
52 | 面向错误的设计
53 | 面向恢复的设计
54 | Chaos Engineering
55 | 结课测试&结束语
登录 后留言

全部留言(10)

  • 最新
  • 精选
数字记忆
这个课程仅作了解,没啥深层次的东西
2021-03-26
2
9
blackpiglet
改了好几遍程序,终于明白为什么要写成这样了, e := &Employee{1, "Mike", 30} 原因是: 1. UpdateAge 必须得声明为 e *Employee 类型的成员变量才能将修改的值保存; 2. Call 调用 UpdateAge 就必须得传入 *Employee 类型的变量才能调用成功。
2019-09-16
9
james
获取反射方法的方法名必须要首字母大写, 否则报错
2020-03-12
3
6
郭星
reflect.ValueOf(指针).MethodByName() reflect.ValueOf(实例).FieldByName() 为什么MethodByName 是指针,而FieldByName是实例?
2020-07-21
2
3
陈启航
主要就是教基础语法 后半部分感觉没有太多逻辑性了
2021-08-22
2
Hao
reflect.ValueOf(<pointer type>).MethodByName() reflect.ValueOf(<non-pointer type>).FieldByName() Why does MethodByName requires a pointer type while FieldByName not? Is there any reason about it?
2019-09-05
1
2
escray
其实之前对于 C# 和 Java 中的反射都有些概念模糊,看代码能看到,但是在项目中主动使用的很少。 反射最大的用途可能就是通过字符串或者以字符的形式来调用类型中的某一个方法,或者通过传入变量或者方法的名字访问某一个成员。 其实在 JavaScript 或者 Ruby 中也用到了反射,只是有时候用了而不自知。 对于留言中的问题,为什么 MethodByName 之前的 ValueOf 传递的参数是指针,而 FieldByName 之前 ValueOf 传递的是实例,我也不太明白,抄一段官方文档: ``` func (v Value) FieldByName(name string) Value ``` FieldByName returns the struct field with the given name. It returns the zero Value if no field was found. It panics if v's Kind is not struct. ``` func (v Value) MethodByName(name string) Value ``` MethodByName returns a function value corresponding to the method of v with the given name. The arguments to a Call on the returned function should not include a receiver; the returned function will always use v as the receiver. It returns the zero Value if no method was found.
2021-04-11
1
疯琴
请问老师,为什么.FieldByName前面要用reflect.ValueOf(*e)而MethodByName前面要用reflect.ValueOf(e),一个是值一个是指针。另外reflect.TypeOf(e).MethodByName("UpdateAge")为什么没有Call方法了?
2019-11-22
2
1
看不见的城市
Name string `format:"normal"` 这个后面 format 啥意思
2021-07-23
Roy
提交一下边学编写的代码: package reflect_test import ( "fmt" "reflect" "testing" ) type Employee struct { EmployeeId int //注意后面的 struct tag 的写法 Name string `format:"normal"` Age int } //更新名字,注意这里的 e 是指针类型 func (e *Employee) UpdateName (newVal string) { e.Name = newVal } //通过反射调用结构体的方法 func TestInvokeByName(t *testing.T) { e := Employee{1, "Jane", 18} //reflect.TypeOf()可以返回两个值,,第二个值可以用来判断这个值有没有; //儿reflect.ValueOf()只会返回一个值 if nameField, ok := reflect.TypeOf(e).FieldByName("Name"); !ok { t.Error("Failed to get 'Name' field") } else { //获取反射取到的字段的 tag 的值 t.Log("Tag:Format", nameField.Tag.Get("format")) } reflect.ValueOf(&e).MethodByName("UpdateName").Call([]reflect.Value{reflect.ValueOf("Mike")}) t.Log("After update name: ", e) } /* === RUN TestInvokeByName reflect_test.go:28: Tag:Format normal reflect_test.go:33: After update name: {1 Mike 18} --- PASS: TestInvokeByName (0.00s) PASS */ //检查反射类型 //用空接口接收任意类型 func CheckType(v interface{}) { t := reflect.TypeOf(v) switch t.Kind() { case reflect.Int, reflect.Int32, reflect.Int64: fmt.Println("Int") case reflect.Float32, reflect.Float64: fmt.Println("Float") default: fmt.Println("unknown type") } } //func TestBasicType(t *testing.T) { // var f float32 = 1.23 // CheckType(f) //} /* === RUN TestBasicType Float --- PASS: TestBasicType (0.00s) PASS */
2021-07-14
收起评论