博客
关于我
反射的快速入门
阅读量: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 10g的安装配置
查看>>
Oracle 11g数据库安装和卸载教程
查看>>
ORACLE Bug 4431215 引发的血案—原因分析篇
查看>>
oracle dblink 创建使用 垮库转移数据
查看>>
oracle dblink结合同义词的用法 PLS-00352:无法访问另一数据库
查看>>
Oracle dbms_job.submit参数错误导致问题(ora-12011 无法执行1作业)
查看>>
oracle dg switchover,DG Switchover fails
查看>>
Oracle EBS-SQL (BOM-15):检查多层BOM(含common BOM).sql
查看>>
Oracle EBS环境下查找数据源(OAF篇)
查看>>
Oracle GoldenGate Director安装和配置(无图)
查看>>
oracle script
查看>>
Oracle select表要带双引号的原因
查看>>
Oracle SOA Suit Adapter
查看>>
Oracle Spatial空间数据库建立
查看>>
UML— 活动图
查看>>
Oracle Statspack分析报告详解(一)
查看>>
oracle tirger_在Oracle中,临时表和全局临时表有什么区别?
查看>>
oracle where 条件的执行顺序分析1
查看>>
oracle 使用leading, use_nl, rownum调优
查看>>
oracle 修改字段类型方法
查看>>