博客
关于我
反射的快速入门
阅读量:666 次
发布时间:2019-03-16

本文共 1634 字,大约阅读时间需要 5 分钟。

反射操作演示:基本数据类型与结构体类型

一、案例一:基本数据类型的反射操作

基本数据类型在反射编程中的应用是一个常见且基础的操作。本案例将演示如何通过反射技术获取基本数据类型变量的类型信息、值以及相关属性。

package mainimport (    "fmt"    "reflect")// 基本数据类型演示反射func reflectTest01(b interface{}) {    // 获取变量的类型    rTyp := reflect.TypeOf(b)    fmt.Println("rType=", rTyp)        // 获取变量的值    rVal := reflect.ValueOf(b)    n2 := 2 + rVal.Int()  // 通过反射获取整数值    fmt.Println("n2=", n2)        // 值的类型确认与转换    iV := rVal.Interface()    num2 := iV.(int)    fmt.Println("num2=", num2)        // 获取值的方法信息    rkind := rVal.Kind()    fmt.Println("kind=", rkind)}

二、案例二:结构体类型的反射操作

结构体类型的反射操作在编程中具有重要意义。通过反射,可以获取结构体变量的内部信息并对其进行增删改查等操作。本案例以一个简单的Student结构体为例,演示结构体类型的反射操作。

type Student struct {    Name string    Age  int}// 结构体演示反射func reflectTest02(b interface{}) {    // 获取变量的类型    rTyp := reflect.TypeOf(b)    fmt.Println("rType=", rTyp)        // 获取变量的值    rVal := reflect.ValueOf(b)        // 获取值的方法信息    kind1 := rVal.Kind()        // reflect.Value 的 Kind()    kind2 := rTyp.Kind()        // reflect.Type 的 Kind()    fmt.Printf("kind = %v (value), kind=%v (type)\n", kind1, kind2)        // 值转换为 Interface{}    iV := rVal.Interface()    fmt.Printf("iv=%v iv type=%T \n", iV, iV)        // 断言为 Student 类型    stu, ok := iV.(Student)    if ok {        fmt.Printf("stu.Name=%v\n", stu.Name)    }}

三、测试结果

测试一:基本数据类型反射

  • rType=int
  • n2=102
  • rVal=100 rVal type=reflect.Value
  • num2=100
  • kind=int

测试二:结构体类型反射

  • rType=main.Student
  • kind = struct kind=struct
  • iv={tom 20} iv type=main.Student
  • stu.Name=tom

这两个案例通过实例展示了反射技术在不同数据类型(基本数据类型和自定义结构体)中的应用方式。

结论

反射是Go语言中一个强大的工具,能够更灵活地操作代码结构。本案例通过实际样例展示了基本数据类型和结构体类型的反射操作,包括如何获取类型信息、变量值以及对结构体字段的访问等内容。理解这些基础操作是掌握反射技术的关键步骤。

转载地址:http://arxqz.baihongyu.com/

你可能感兴趣的文章
oracle 11g 静默安装
查看>>
Oracle 11gR2学习之二(创建数据库及OEM管理篇)
查看>>
Oracle 11gR2构建RAC之(2)--配置共享存储
查看>>
Oracle 11g中的snapshot standby特性
查看>>
Oracle 11g关闭用户连接审计
查看>>
Oracle 11g忘记sys、system、scott密码该这样修改!
查看>>
Oracle 11g数据库安装和卸载教程
查看>>
Oracle 11g数据库成功安装创建详细步骤
查看>>
Oracle 11g超详细安装步骤
查看>>
Oracle 12c中的MGMTDB
查看>>
Oracle 12c安装报错Installation failed to access the temporary location(无法访问临时位置)...
查看>>
Oracle 9i数据库管理教程
查看>>
ORACLE Active dataguard 一个latch: row cache objects BUG
查看>>
oracle avg、count、max、min、sum、having、any、all、nvl的用法
查看>>
Oracle BEQ方式连接配置
查看>>
oracle Blob保存方式,oracle 存储过程操作blob
查看>>
Oracle BMW Racing sailing vessel帆船图
查看>>
ORACLE Bug 4431215 引发的血案—原因分析篇
查看>>
Oracle Business Intelligence Downloads
查看>>
Oracle cmd乱码
查看>>