失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > Go语言数据类型

Go语言数据类型

时间:2023-04-27 06:06:38

相关推荐

Go语言数据类型

Go语言数据类型

GO语言学习教程

Go 语言按类别有以下几种数据类型:

Go在大小写方面它有一些默认的行为:

大写字母开头的变量是,是公有变量;小写字母开头的是私有变量。大写字母开头的函数也是一样,相当于java中的带public关键词的公有函数;小写字母开头的相当于private关键词的私有函数。

数字类型:

Go 也有基于架构的类型,例如:int、uint 和 uintptr。

浮点型:

其他数字类型

复合类型(派生类型)

举例如下

整型

Go1.13版本之后引入了数字字面量语法,这样便于开发者以二进制、八进制或十六进制浮点数的格式定义数字,例如:

v := 0b00101101, 代表二进制的 101101,相当于十进制的 45。 v := 0o377,代表八进制的 377,相当于十进制的 255。 v := 0x1p-2,代表十六进制的 1 除以 2²,也就是 0.25。 而且还允许我们用 _ 来分隔数字,比如说:

v := 123_456 等于 123456。

package mainimport "fmt"func main(){// 十进制var a int = 10fmt.Printf("%d \n", a) // 10fmt.Printf("%b \n", a) // 1010 占位符%b表示二进制// 八进制 以0开头var b int = 077fmt.Printf("%o \n", b) // 77// 十六进制 以0x开头var c int = 0xfffmt.Printf("%x \n", c) // fffmt.Printf("%X \n", c) // FF}

浮点型

Go语言支持两种浮点型数:float32和float64。这两种浮点型数据格式遵循IEEE 754标准: float32 的浮点数的最大范围约为 3.4e38,可以使用常量定义:math.MaxFloat32。 float64 的浮点数的最大范围约为 1.8e308,可以使用一个常量定义:math.MaxFloat64。

打印浮点数时,可以使用fmt包配合动词%f,代码如下

package mainimport ("fmt""math")func main() {fmt.Printf("%f\n", math.Pi)fmt.Printf("%.2f\n", math.Pi)}

布尔值

Go语言中以bool类型进行声明布尔型数据,布尔型数据只有true(真)和false(假)两个值

注意:

布尔类型变量的默认值为false。Go 语言中不允许将整型强制转换为布尔型.布尔型无法参与数值运算,也无法与其他类型进行转换。

字符串

Go语言中的字符串以原生数据类型出现,使用字符串就像使用其他原生数据类型(int、bool、float32、float64 等)一样。 Go 语言里的字符串的内部实现使用UTF-8编码。 字符串的值为双引号(")中的内容,可以在Go语言的源码中直接添加非ASCII码字符,例如:

s1 := "hello"s2 := "你好"

字符串转义符

Go 语言的字符串常见转义符包含回车、换行、单双引号、制表符等,如下表所示。

多行字符串

Go语言中要定义一个多行字符串时,就必须使用反引号`字符:

s1 := `第一行第二行第三行`fmt.Println(s1)

反引号间换行将被作为字符串中的换行,但是所有的转义字符均无效,文本将会原样输出。

字符串的常用操作

byte和rune类型

组成每个字符串的元素叫做“字符”,可以通过遍历或者单个获取字符串元素获得字符。 字符用单引号(’)包裹起来,如:

var a := '中'var b := 'x'

Go 语言的字符有以下两种:

uint8类型,或者叫 byte 型,代表了ASCII码的一个字符。rune类型,代表一个 UTF-8字符。

当需要处理中文、日文或者其他复合字符时,则需要用到rune类型。rune类型实际是一个int32。

Go 使用了特殊的 rune 类型来处理 Unicode,让基于 Unicode 的文本处理更为方便,也可以使用 byte 型进行默认字符串处理,性能和扩展性都有照顾。

// 遍历字符串func traversalString() {s := "hello沙河"for i := 0; i < len(s); i++ {//bytefmt.Printf("%v(%c) ", s[i], s[i])}fmt.Println()for _, r := range s {//runefmt.Printf("%v(%c) ", r, r)}fmt.Println()}

输出

104(h) 101(e) 108(l) 108(l) 111(o) 230(æ) 178(²) 153() 230(æ) 178(²) 179(³) 104(h) 101(e) 108(l) 108(l) 111(o) 27801(沙) 27827(河)

因为UTF8编码下一个中文汉字由3~4个字节组成,所以我们不能简单的按照字节去遍历一个包含中文的字符串,否则就会出现上面输出中第一行的结果。

字符串底层是一个byte数组,所以可以和[]byte类型相互转换。字符串是不能修改的 字符串是由byte字节组成,所以字符串的长度是byte字节的长度。 rune类型用来表示utf8字符,一个rune字符由一个或多个byte组成。

修改字符串

要修改字符串,需要先将其转换成[]rune或[]byte,完成后再转换为string。无论哪种转换,都会重新分配内存,并复制字节数组。

func changeString() {s1 := "big"// 强制类型转换byteS1 := []byte(s1)byteS1[0] = 'p'fmt.Println(string(byteS1))s2 := "白萝卜"runeS2 := []rune(s2)runeS2[0] = '红'fmt.Println(string(runeS2))}

类型转换

Go语言中只有强制类型转换,没有隐式类型转换。该语法只能在两个类型之间支持相互转换的时候使用。

强制类型转换的基本语法如下:

T(表达式)

其中,T表示要转换的类型。表达式包括变量、复杂算子和函数返回值等.

比如计算直角三角形的斜边长时使用math包的Sqrt()函数,该函数接收的是float64类型的参数,而变量a和b都是int类型的,这个时候就需要将a和b强制类型转换为float64类型。

func sqrtDemo() {var a, b = 3, 4var c int// math.Sqrt()接收的参数是float64类型,需要强制转换c = int(math.Sqrt(float64(a*a + b*b)))fmt.Println(c)}

练习编写代码统计出字符串"Hello 中国你好 World"中汉字的数量。

package mainimport ("fmt""unicode")func isHan(r rune) bool {return unicode.Is(unicode.Han, r)}func main() {words:="Hello 中国你好 World"var data []rune = []rune(words)sum:=0fmt.Println(len(data))for i:=0;i<len(data) ; i++ {b := data[i]if isHan(b) {sum++}}fmt.Printf("%s含有%d个汉字",words,sum)}

GO语言学习教程

如果觉得《Go语言数据类型》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。