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

简介: 这篇文章介绍了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 = 10
    b = 33.3
)

func main() {
   
    var number1 int = a
    var number2 float32 = a + b // 转换成为 float32 数据类型
    fmt.Println(number1, number2)// 10 43.3
    fmt.Printf("%T\n%T\n",number1,number2)// int  float32
}

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

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

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

package main
import "fmt"
const(
    blue = 1
    yellow 
    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 << iota
    n2
    n3
    n4 = 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 = 1
        n2 = 2
        n3 = 3
        n4 = 4
    )
    // 使用iota的枚举常量定义
    const(
        _ = iota
        n1 
        n2
        n3
        n4
    )
    

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

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


相关文章
|
7天前
|
存储 编译器 Go
go语言中的变量、常量、数据类型
【11月更文挑战第3天】
25 9
|
13天前
|
Go
go语言的复数常量
【10月更文挑战第21天】
33 6
|
13天前
|
Go
go语言的浮点型常量
【10月更文挑战第21天】
21 4
|
13天前
|
编译器 Go
go语言的整型常量
【10月更文挑战第21天】
29 3
|
5天前
|
存储 JSON 监控
Viper,一个Go语言配置管理神器!
Viper 是一个功能强大的 Go 语言配置管理库,支持从多种来源读取配置,包括文件、环境变量、远程配置中心等。本文详细介绍了 Viper 的核心特性和使用方法,包括从本地 YAML 文件和 Consul 远程配置中心读取配置的示例。Viper 的多来源配置、动态配置和轻松集成特性使其成为管理复杂应用配置的理想选择。
23 2
|
3天前
|
Go 索引
go语言中的循环语句
【11月更文挑战第4天】
11 2
|
3天前
|
Go C++
go语言中的条件语句
【11月更文挑战第4天】
14 2
|
8天前
|
Ubuntu 编译器 Linux
go语言中SQLite3驱动安装
【11月更文挑战第2天】
31 7
|
8天前
|
关系型数据库 Go 网络安全
go语言中PostgreSQL驱动安装
【11月更文挑战第2天】
38 5
|
8天前
|
安全 Go
用 Zap 轻松搞定 Go 语言中的结构化日志
在现代应用程序开发中,日志记录至关重要。Go 语言中有许多日志库,而 Zap 因其高性能和灵活性脱颖而出。本文详细介绍如何在 Go 项目中使用 Zap 进行结构化日志记录,并展示如何定制日志输出,满足生产环境需求。通过基础示例、SugaredLogger 的便捷使用以及自定义日志配置,帮助你在实际开发中高效管理日志。
25 1