Go語言基礎(chǔ)枚舉的用法及示例詳解

概述
將變量的值一一列舉出來,變量只限于列舉出來的值的范圍內(nèi)取值
Go語言中沒有枚舉這種數(shù)據(jù)類型的,但是可以使用const配合iota模式來實(shí)現(xiàn)
一、普通枚舉
const ( cpp = 0 java = 1 python = 2 golang = 3 )
二、自增枚舉
iota只能在常量的表達(dá)式中使用
fmt.Println(iota) //undefined: iota
它默認(rèn)開始值是0,const中每增加一行加1
const (
a = iota //0
c //1
d //2
)
每次 const 出現(xiàn)時(shí),都會(huì)讓 iota 初始化為0
const d = iota // a=0 const ( e = iota //b=0 f //c=1 )
如果中斷iota,必須顯式恢復(fù)?。?!
const (
Low = iota //0
Medium //1
High = 100 //100
Super //100
Band = iota //4
)
如果是同一行,值都一樣
const ( i = iota j1, j2, j3 = iota, iota, iota k = iota )
可跳過的值
const ( k1 = iota // 0 k2 // 1 _ //2 _ //3 k3 // 4 )
中間插入一個(gè)值
const ( Sun = iota //Sun = 0 Mon // Mon = 1 Tue = 7 //7 Thu = iota // 3 Fri //4 )
注意
- iota 必須配合const 使用,否則undefined: iota
- 每次 const 出現(xiàn)時(shí),都會(huì)讓 iota 初始化為0
- 如果是同一行,值都一樣
代碼
package main
import "fmt"
func main() {
//普通枚舉
const (
cpp = 0
java = 1
python = 2
)
fmt.Printf("cpp=%d java=%d python=%d\n", cpp, java, python) //a=0 b=1 c=2
//1.iota只能在常量的表達(dá)式中使用
//fmt.Println(iota) //undefined: iota
//2.它默認(rèn)開始值是0,const中每增加一行加1
const (
a = iota //0
b //1
c //2
)
fmt.Printf("a=%d b=%d c=%d\n", a, b, c) //a=0 b=1 c=2
//3.每次 const 出現(xiàn)時(shí),都會(huì)讓 iota 初始化為0
const d = iota // a=0
const (
e = iota //b=0
f //c=1
)
fmt.Printf("d=%d e=%d f=%d\n", d, e, f) //d=0 e=0 f=1
//4.如果中斷iota,必須顯式恢復(fù)?。?!
const (
Low = iota //0
Medium //1
High = 100 //100
Super //100
Band = iota //4
)
//Low=0 Medium=1 High=100 Super=100 Band=4
fmt.Printf("Low=%d Medium=%d High=%d Super=%d Band=%d\n", Low, Medium, High, Super, Band)
//5.如果是同一行,值都一樣
const (
i = iota
j1, j2, j3 = iota, iota, iota
k = iota
)
//i=0 j1=1 j2=1 j3=1 k=2
fmt.Printf("i=%d j1=%d j2=%d j3=%d k=%d\n", i, j1, j2, j3, k)
//6.可跳過的值
const (
k1 = iota // 0
k2 // 1
_ //2
_ //3
k3 // 4
)
// k1=0 k2=1 k3=4
fmt.Printf("k1=%d k2=%d k3=%d \n", k1, k2, k3)
//7.中間插入一個(gè)值
const (
Sun = iota //Sun = 0
Mon // Mon = 1
Tue = 7 //7
Thu = iota // 3
Fri //4
)
//Sun=0 Mon=1 Tue=7 Thu=3 Fri=4
fmt.Printf("Sun=%d Mon=%d Tue=%d Thu=%d Fri=%d\n", Sun, Mon, Tue, Thu, Fri)
}
以上就是Go語言基礎(chǔ)枚舉的用法及示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Go語言枚舉的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
golang中定時(shí)器cpu使用率高的現(xiàn)象詳析
這篇文章主要給大家介紹了關(guān)于golang中定時(shí)器cpu使用率高的現(xiàn)象的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-04-04
深入分析Golang Server源碼實(shí)現(xiàn)過程
這篇文章深入介紹了Golang Server源碼實(shí)現(xiàn)過程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-02-02
Go語言實(shí)戰(zhàn)學(xué)習(xí)之流程控制詳解
這篇文章主要為大家詳細(xì)介紹了Go語言中的流程控制,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Go語言有一定的幫助?,需要的朋友可以參考下2022-08-08
Go語言實(shí)現(xiàn)Snowflake雪花算法
雪花算法產(chǎn)生的背景當(dāng)然是twitter高并發(fā)環(huán)境下對唯一ID生成的需求,得益于twitter內(nèi)部牛的技術(shù),雪花算法能夠流傳于至今并且被廣泛使用,本文就詳細(xì)的介紹一下,感興趣的可以了解一下2021-06-06
Go語言實(shí)現(xiàn)字符串搜索算法Boyer-Moore
Boyer-Moore?算法是一種非常高效的字符串搜索算法,被廣泛的應(yīng)用于多種字符串搜索場景,下面我們就來學(xué)習(xí)一下如何利用Go語言實(shí)現(xiàn)這一字符串搜索算法吧2023-11-11
詳解如何在Go中實(shí)現(xiàn)優(yōu)雅停止
和其他語言相比,Go 中有相同也有不同,相同的是實(shí)現(xiàn)思路上和其他語言沒啥差異,不同在于 Go 采用的是 goroutine + channel 的并發(fā)模型,與傳統(tǒng)的進(jìn)程線程相比,實(shí)現(xiàn)細(xì)節(jié)上存在差異,本文將從實(shí)際場景和它的一般實(shí)現(xiàn)方式展開,逐步討論這個(gè)話題,需要的朋友可以參考下2024-04-04

