当前位置: 首页 > news >正文

Go常量的定义和使用const,const特性“隐式重复前一个表达式”,以及iota枚举常量的使用

Go常量的定义和使用const,以及iota枚举常量的使用

    • Go常量const
    • Go中常量的定义和使用
      • Go特性const,"隐式重复前一个表达式"
    • iota 实现枚举常量

Go常量const

Go语言中的const整合了C语言中的宏定义常量,const只读变量枚举变量

  1. 绝大多数情况下,Go常量在声明时,并不显示的指定类型
  2. Go在处理不同类型的变量间的运算时不支持隐式的类型转换,必须进行显示的类型转换。
  3. Go的无类型常量,拥有字面量的特性。该特性使得无类型常量在参与变量赋值和计算过程中,无需显示的进行类型转换

无类型常量使得go在处理表达式混合数据类型运算时具有很高的灵活性。

Go中常量的定义和使用

定义格式:

const (常量名 =......
)

在const代码块中进行对常量的声明,一般使用时,多数使用无类型常量定义。

例如,定义两个无类型常量,在使用时会自动进行类型的隐式转换,很方便:

package main
import "fmt"// 在const代码块中进行常量的声明定义
const (a = 10b = 33.3
)func main() {var number1 int = avar number2 float32 = a + b // 转换成为 float32 数据类型fmt.Println(number1, number2)// 10 43.3fmt.Printf("%T\n%T\n",number1,number2)// int  float32
}

无类型常量是Go语言推荐的最佳实践,它拥有和字面值一样的灵活性,可以直接用于更多的表达式而不需要显示的进行类型转换。

Go特性const,“隐式重复前一个表达式”

在Go的const语法中,提供了一个“隐式重复前一个表达式”的机制。

package main
import "fmt"
const(blue = 1yellow green blank
)func main(){fmt.Printf("%d\t%d\t%d\t%d\t",blue,yellow,green,blank)\\ 1       1       1       1
}

可以很神奇的发现,在const定义的常量中,如果没有确切的赋值,则会隐式的重复前一个表达式的机制。如上面,我们将blue初始化为1,后续的常量初值并不进行初始化,则其余常量值都会变为1(隐式的重复前一个表达式的机制)。这个机制在iota实现枚举常量中十分常用。

iota 实现枚举常量

iota是Go提供的一个预定义标识符,它在const声明块中每个常量所处位置在块中的偏移,每一行的iota自身都是一个无类型常量,可以像无类型常量那样自动参与不同类型的求值过程,而无须对其进行显示的类型转换。

例如:

package main
import "fmt"
// 使用iota实现go语言中的枚举常量enum
const (n1 = 1 << iotan2n3n4 = iota
)func main() {fmt.Printf("%d\t%d\t%d\t%d\t", n1, n2, n3, n4)// 1       2       4       3
}

分析一波上面的代码:

  1. n1 = 1<<iota时,n1=1,iota=0
  2. n2时,由于在const中定义,若未初始化常量值,则会隐式的重复前一个表达式,则n2 =1<<iota,此时n2=2,iota=1(偏移量为1)
  3. n3时,与n2一致(隐式的重复前一个表达式),n3=2<<iota,n3=4,iota=2
  4. n4=iota,此时iota的偏移量为4,则n4=4

iota 使得 Go在定义枚举常量时十分灵活和方便:

  1. iota预定义标识符可以更为灵活的形式为枚举常量赋值

  2. Go的枚举常量不限定于整数值,也可以定义浮点型的枚举常量

  3. iota使得维护枚举常量列表更为容易(对比一下传统的常量列表定义和使用iota的const常量定义

    // 不使用iota的传统枚举常量定义
    const(n1 = 1n2 = 2n3 = 3n4 = 4
    )
    // 使用iota的枚举常量定义
    const(_ = iotan1 n2n3n4
    )
    

    当我们需要为常量列表中添加某一个常量时,如果使用第一种传统的方式定义,则需要手动的进行定义和赋值(同时你也需要观察旧的枚举列表,从而对新添加的常量进行赋值),而使用第二种iota时,则可以很灵活的自由添加。

  4. 使用有类型枚举常量保证类型安全。


http://www.lryc.cn/news/23978.html

相关文章:

  • Git学习(1)pro git阅读
  • PHY自协商
  • 【大数据离线开发】8.2 Hive的安装和配置
  • Capture Modules:车载网络报文捕获模块
  • 数据结构与算法系列之时间与空间复杂度
  • Python代码使用PyQt5制作界面并封装
  • 【Node.js】MySQL数据库的第三方模块(mysql)
  • Docker中安装并配置单机版redis
  • 模拟微信聊天-课后程序(JAVA基础案例教程-黑马程序员编著-第八章-课后作业)
  • html2canvas将页面dom元素内容渲染成图片保存至本地
  • 前端进阶JS运行原理
  • Python识别二维码的两种方法(cv2)
  • 用一个例子告诉你 怎样使用Spark中RDD的算子
  • 什么是跨域? 出现原因及解决方法
  • 低代码系统能够解决哪些痛点?
  • 华为OD机试题,用 Java 解【两数之和绝对值最小】问题
  • AcWing算法提高课-3.1.1热浪
  • 华为OD机试题【最差产品奖】用 C++ 编码,速通 (2023.Q1)
  • NFT市场大战:Blur市场地位可持续吗?
  • 初识CSS
  • kubernetes(k8s)知识总结(第3期)
  • 浅谈跨境电商运行模式
  • Memcached
  • Unity UGUI 拖拽组件
  • 面试总结——react生命周期
  • 初探推荐系统-01
  • html实现浪漫的爱情日记(附源码)
  • detectron2容器环境安装问题(1)
  • JAVA线程池原理详解二
  • Java 常用 API