整形
类型转换举例
var ia int64 = 54345 var ib int32 ib = int32(ia) fmt.Println("ibis", ib)
浮点形
go语言定义了两个浮点型
float32 等价于C语言的float类型,
float64 等价于C语言的double类型
float64 等价于C语言的double类型
浮点数的比较 math.Fdim(f1, f2) < p p为定义的精度 如 0.00000001
字符串
var str1 string str1 = "this is first string" str2 := "this is second string" str3 := str1 + str2 fmt.Printf("the string str3: %s \n len: %d \n first char is %c \n", str3, len(str3), str3[0])
字符串可以用常规方法for循环遍历,应用len取的字符串长度,用str3[i]取值,依据下标取字符串中的字符,类型为byte,这里用另一种方法遍历:
for i, ch := range str3 { //fmt.Println(i, ch, "\n") 以Unicode字符方式遍历时,每个字符的类型是rune fmt.Printf("%d, %c", i, ch) }
字符类型
go支持两种字符类型:byte(实际上是uint8的别名),代表UTF-8字符串的单个字节的值
rune 代表单个Unicode字符 于rune相关的操作,可查阅Go标准库的unicode包。另外unicode/utf8包也提供了UTF8和Unicode之间的转换。
注意:出于简化语言的考虑,Go语言的多数API都假设字符串为UTF-8编码。尽管Unicode字符在标准库中有支持,但实际上较少使用。
数组
go中数组由一组相同类型的元素构成,其长度声明后不可改变,数组常规声明方法
[32]byte // 长度为32的数组,每个元素为一个字节 [2*N] struct { x, y int32 } // 复杂类型数组 [1000]*float64 // 指针数组 [3][5]int // 二维数组 [2][2][2]float64 // 等同于[2]([2]([2]float64))GO中数组小标同C,从0开始
数组遍历
var array [2]struct { x string y uint64 } array[0].x = "first" array[0].y = 888888 array[1].x = "secon" array[1].y = 99999 for i, v := range array { fmt.Println("Array element[", i, "]=", v.x, v.y, "\n") }注意:在GO中数组是值类型,所有的值类型变量在赋值和作为参数传递时都将产生一次复制动作。
数组切片
初看起来,数组切片就像一个指向数组的指针,实际上它拥有自己的数据结构,而不仅仅是个指针。数组切片的数据结构可以抽象为以下3个变量:
- 一个指向原生数组的指针;
- 数组切片中的元素个数;
- 数组切片已分配的存储空间。
基于数组或数组切片
可基于已有数组创建少于或等于,甚至比原有数组更大的数组切片
Go语言支持用myArray[first:last]来创建数组切片:myArray[:] 整个,myArray[:5] 前五个,myArray[5:] 从第五个开始
// 先定义一个数组 var myArray [10]int = [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10} // 基于数组创建一个数组切片 var mySlice []int = myArray[:5] fmt.Println("Elements of myArray: ") for _, v := range myArray { fmt.Print(v, " ") } fmt.Println("\nElements of mySlice: ") for _, v := range mySlice { fmt.Print(v, " ") } fmt.Println()直接创建
GO可以用内置函数make(),灵活创建数组切片
make 第一个参数定义数组类型如 []int, 第二个参数为元素个数, 第三个参数为预留存储空间,可以缺省
创建一个初始元素个数为5的数组切片,元素初始值为0: mySlice1 := make([]int, 5) 创建一个初始元素个数为5的数组切片,元素初始值为0,并预留10个元素的存储空间: mySlice2 := make([]int, 5, 10) 直接创建并初始化包含5个元素的数组切片: mySlice3 := []int{1, 2, 3, 4, 5}元素遍历同数组
动态增减
GO中可用 append()向数组切片尾部增加元素,该函数的第二参数为不定长参数,可以按需传人
另外还可以将一个数组切片用...打散后添加到数组切片后面
arr1 := make([]int64, 5) for _, v := range arr1 { fmt.Print(" ", v) } fmt.Println() arr1 = append(arr1, 3, 4, 5) for _, v := range arr1 { fmt.Print(" ", v) } fmt.Println() arr2 := []int64{8, 8, 8, 8, 8} arr1 = append(arr1, arr2...) for _, v := range arr1 { fmt.Print(" ", v) } fmt.Println()内容复制
slice1 := []int{1, 2, 3, 4, 5} slice2 := []int{5, 4, 3} copy(slice2, slice1) // 只会复制slice1的前3个元素到slice2中 copy(slice1, slice2) // 只会复制slice2的3个元素到slice1的前3个位置
MAP
GO中,map是内置的,是一堆键值对的未排序集合。
<span style="white-space:pre"> </span>type book struct { Name string Actor string Price float64 } var booksMap map[string]book //声明 booksMap = make(map[string]book) //创建 booksMap["123456"] = book{"go web 编程", "tom.sd", 64.2} booksMap["443"] = book{"go编程语言", "tom.ddd", 55.2} book1, ok := booksMap["443"] //查找 if ok { fmt.Println("book1 ", book1.Name, book1.Actor, book1.Price) book1.Price = 88.8 booksMap["443"] = book1 //修改 } book2, ok := booksMap["443"] if ok { fmt.Println("book1 ", book2.Name, book2.Actor, book2.Price) //book1.Price = 88.8 }
delete(booksMap,"443")
有疑问加站长微信联系(非本文作者)