Go基本数据类型的具体使用
作者:hope_wisdom
概述
在上一节的内容中,我们介绍了Go的基础语法,包括:标识符、关键字、行分隔符、var关键字、:=运算符、空格、注释、package、import、输入输出、运算符、条件控制、循环等。在本节中,我们将介绍Go的基本数据类型。Go语言是一种静态类型的编程语言,这也就意味着,声明变量需要指定其具体类型,或者交由编译器进行自动推导。在Go语言中,数据类型是编程的基础,它定义了变量或表达式的存储方式和行为。
布尔类型
布尔类型(Boolean)用于表示真或假的值,可以为true或false。布尔类型被声明为bool,可以使用条件语句或逻辑运算符进行比较和操作。
package main import "fmt" func main() { var success bool = true if success { fmt.Println("Success") } else { fmt.Println("Failed") } }
与C/C++语言不同,Go语言中的布尔值并不会隐式转换为数字值0或1,反之亦然。另外,Go语言也不允许将整型强制转换为布尔型。
package main import "fmt" func main() { var age int = 18 // 不允许将整型强制转换为布尔型,会发生编译错误 var larger bool = bool(age) // 布尔值不会隐式转换为数字值,会发生编译错误 age = larger if larger { fmt.Println("Success") } else { fmt.Println("Failed") } }
整数类型
整数类型(Integer)用于表示整数值,包括正数、负数和零。Go语言同时提供了有符号和无符号的整数类型,其中有符号整数包括:int8、int16、int32、int64,分别对应 8、16、32、64位大小的有符号整数,无符号整数包括:uint8、uint16、uint32、uint64,分别对应 8、16、32、64位大小的无符号整数。
另外,还有两种整数类型int和uint,分别对应特定CPU平台的字长。其中int表示有符号整数,应用最为广泛,uint表示无符号整数。由于编译器和计算机硬件的不同,int和uint所能表示的整数大小会在32位和64位之间变化。
注意:尽管在某些特定的运行环境下,int、uint、int32、uint32的大小可能相等,但它们仍然属于不同的数据类型。比如:int类型的大小可能是32位,但需要把int类型当做int32类型使用时,必须显式对类型进行转换,反之亦然。
除了上述的基本整数类型,Go语言还提供了其他几种整数类型,包括:
- rune:该类型表示Unicode码点,通常用来表示一个Unicode字符。
- byte:与uint8是同义词,表示一个字节。
- uintptr:该类型的大小不确定,与平台和编译器有关,但足以存放指针。uintptr通常用于底层编程,特别是与C程序库交互的地方。
package main import "fmt" func main() { var num1 int8 = 66 var num2 uint16 = 3666 var num3 int = 99 fmt.Println(num1, num2, num3) // int不能直接转换为int32,输出:cannot use num3 // (variable of type int) as int32 value in variable declaration // var num4 int32 = num3 // 使用类型转换,可以将int转换为int32 var num4 int32 = int32(num3) fmt.Println(num4) var num5 byte = 100 fmt.Println(num5) }
浮点数类型
浮点数类型(Float)用于表示带有小数点的数值,Go语言提供了float32(32位单精度浮点数)和float64(64位双精度浮点数)两种浮点数类型。单精度浮点数在内存中占用32位(4字节),可以表示的范围大约是±1.18E-38到±3.4E+38。双精度浮点数在内存中占用64位(8字节),可以表示的范围更大,大约是±2.23E-308到±1.80E+308。在Go语言中,可以使用关键字float32、float64来分别声明和初始化单精度浮点数、双精度浮点数。
package main import "fmt" import "math" func main() { var num1 float32 = 3.1415926535 // 输出: 3.1415927 fmt.Println(num1) var num2 float64 = 3.1415926535 // 输出: 3.1415926535 fmt.Println(num2) epsilon := 0.00001 num3 := 3.1415926 // 浮点数比较,输出:equal if math.Abs(num2 - num3) < epsilon { fmt.Println("equal") } else { fmt.Println("not equal") } }
注意:由于浮点数的精度问题,在进行浮点数计算时可能会产生误差。为了避免误差问题,尽量避免进行浮点数比较或直接比较浮点数的相等性,而应使用一个小的容忍度值进行比较。
复数类型
复数类型(Complex)用于表示复数值,由实部和虚部组成。Go语言提供了complex64(64位实数和虚数的复数)和complex128(128位实数和虚数的复数)两种复数类型。
package main import "fmt" func main() { var num1 complex64 = 3.14 + 66i // 输出复数的实部和虚部,输出:3.140000 + 66.000000i fmt.Printf("%f + %fi\n", real(num1), imag(num1)) var num2 complex64 = 10 + 10i var num = num1 + num2 // 复数相加,输出:13.140000 + 76.000000i fmt.Printf("%f + %fi\n", real(num), imag(num)) }
注意:Go语言的复数类型是支持加、减、乘、除等基本运算的,可以使用相应的运算符进行复数运算。
字符串类型
字符串类型(String)用于表示文本数据,字符串是由零个或多个字符组成的不可变序列。Go语言中的字符串是不可变的字节序列,每个字符串都由一个指向字节数组的指针和长度组成。字符串的长度可以通过len()函数获取,而字符串的内容可以通过索引访问。
package main import "fmt" func main() { var str string = "Hello" length := len(str) // 输出字符串长度:5 fmt.Println(length) // 取第一个字符 firstChar := str[0] // 取最后一个字符 lastChar := str[len(str) - 1] // 输出:H, o fmt.Printf("%c, %c\n", firstChar, lastChar) }
字符串还可进行连接、切片、比较、替换、分割等操作,可参考下面的示例代码。
package main import "fmt" import "strings" func main() { var str1 string = "Hello" str2 := "CSDN" // 字符串连接,输出:Hello CSDN str := str1 + " " + str2 fmt.Println(str) // 字符串切片,从索引0开始,到索引5结束(不包括5),输出:Hello slice := str[0:5] fmt.Println(slice) // 字符串比较,输出:larger if str1 > str2 { fmt.Println("larger") } else { fmt.Println("equal or smaller") } // 字符串替换,将"CSDN"替换为"Go",第四个参数为替换的次数,-1表示替换所有匹配的子字符串 newStr := strings.Replace(str, "CSDN", "Go", -1) // 输出:Hello Go fmt.Println(newStr) // 字符串分割,以空格为分隔符,输出:[Hello CSDN] subStrs := strings.Split(str, " ") fmt.Println(subStrs) }
到此这篇关于Go基本数据类型的具体使用的文章就介绍到这了,更多相关Go 数据类型内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!