Go语言切片,范围,集合

简介: 1.Go 语言切片(Slice)概述Go 语言切片是对数组的抽象。Go 数组的长度不可改变,在特定场景中这样的集合就不太适用,Go 中提供了一种灵活,功能强悍的内置类型切片(“动态数组”),与数组相比切片的长度是不固定的,可以追加元素,在追加时可能使切片的容量增大。


1.Go 语言切片(Slice)


概述


Go 语言切片是对数组的抽象。


Go 数组的长度不可改变,在特定场景中这样的集合就不太适用,Go 中提供了一种灵活,功能强悍的内置类型切片(“动态数组”),与数组相比切片的长度是不固定的,可以追加元素,在追加时可能使切片的容量增大。


定义切片


你可以声明一个未指定大小的数组来定义切片:


var identifier []type
var si []int


或使用 make() 函数来创建切片:


var slice1 []type = make([]type, len)
也可以简写为
slice1 := make([]type, len)


也可以指定容量,其中 capacity 为可选参数


make([]T, length, capacity)


这里 len 是数组的长度并且也是切片的初始长度


切片初始化


s :=[] int {1,2,3 }


len() 和 cap() 函数


切片是可索引的,并且可以由 len() 方法获取长度。

切片提供了计算容量的方法 cap() 可以测量切片最长可以达到多少。


package main
import "fmt"
func main() {
  var numbers = make([]int, 3, 5)
  fmt.Println(len(numbers), cap(numbers), numbers)  // 3 5 [0 0 0]


空(nil)切片

一个切片在未初始化之前默认为 nil,长度为 0,实例如下:


package main
import "fmt"
func main() {
  var numbers []int
  if numbers == nil {
    fmt.Println("切片为空")  // 切片为空
  }
}


切片截取


package main
import "fmt"
func main() {
  numbers := []int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
  fmt.Println(numbers)  // [0 1 2 3 4 5 6 7 8 9]
  fmt.Println(numbers[1:4])  // [1 2 3]     
  fmt.Println(numbers[:3])  // [0 1 2]   
  fmt.Println(numbers[4:])  // [4 5 6 7 8 9]
}


append() 和 copy() 函数


append()


package main
import "fmt"
func main() {
  numbers := []int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
  /* 向切片添加一个元素 */
  numbers = append(numbers, 521)
  /* 同时添加多个元素 */
  numbers = append(numbers, 11, 12, 13)
  fmt.Println(numbers)  // [0 1 2 3 4 5 6 7 8 9 521 11 12 13]
}


copy()


package main
import "fmt"
func main() {
  numbers := []int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
  /* 创建切片 numbers1 是之前切片的两倍容量*/
  numbers1 := make([]int, len(numbers), (cap(numbers))*2)
  copy(numbers1, numbers)
  fmt.Println(numbers1)  // [0 1 2 3 4 5 6 7 8 9]
}


2.Go 语言范围(Range)


Go 语言中 range 关键字用于 for 循环中迭代数组(array)、切片(slice)、通道(channel)或集合(map)的元素。在数组和切片中它返回元素的索引和索引对应的值,在集合中返回 key-value 对。

实例1:


package main
import "fmt"
func main() {
  // 使用range去求一个slice的和。使用数组跟这个很类似
  nums := []int{2, 3, 4}
  sum := 0
  for _, num := range nums {
    sum += num
  }
  fmt.Println(sum)  // 9
}


实例2:


package main
import "fmt"
func main() {
  // 使用range去求一个slice的和。使用数组跟这个很类似
  nums := []int{2, 3, 4}
  sum := 0
  for i, num := range nums {
    sum += num
    fmt.Println(i)
  }
  fmt.Println(sum)
}
----------------------------------
输出:
0
1
2
9


实例3:range也可以用来枚举Unicode字符串。第一个参数是字符的索引,第二个是字符(Unicode的值)本身。


package main
import "fmt"
func main() {
  for i, c := range "hello" {
    fmt.Println(i, c)
  }
}
---------------------------------------
输出:
0 104
1 101
2 108
3 108
4 111


3.Go 语言Map(集合)


Map 是一种无序的键值对的集合。Map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值。

Map 是一种集合,所以我们可以像迭代数组和切片那样迭代它。不过,Map 是无序的,我们无法决定它的返回顺序,这是因为 Map 是使用 hash 表来实现的。

实例1:


package main
import "fmt"
func main() {
  var country map[string]string
  country = make(map[string]string)
  /* map插入key - value对 */
  country["France"] = "巴黎"
  country["beijing"] = "北京"
  country["Japan"] = "日本"
  /* 使用键输出地图值 */
  for cou := range country {
    fmt.Println(cou, "+", country[cou])
  }
}
-------------------------------------------------
输出:
France + 巴黎
beijing + 北京
Japan + 日本  


实例2:


package main
import "fmt"
func main() {
  var country map[string]string
  country = make(map[string]string)
  /* map插入key - value对 */
  country["France"] = "巴黎"
  country["beijing"] = "北京"
  country["Japan"] = "日本"
  /* 查看元素在集合中是否存在 */
  capital, ok := country["American"]
  if ok {
    fmt.Println(capital)
  } else {
    fmt.Println("American的首都不存在")
  }
}
----------------------------------------
输出:
American的首都不存在


实例3:delete() 函数用于删除集合的元素


package main
import "fmt"
func main() {
  var country map[string]string
  country = make(map[string]string)
  /* map插入key - value对 */
  country["France"] = "巴黎"
  country["beijing"] = "北京"
  country["Japan"] = "日本"
  delete(country, "Japan")
  fmt.Println(country)
}
------------------------------------
输出:map[France:巴黎 beijing:北京]
目录
相关文章
|
24天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
72 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
44 7
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
1月前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
111 71
|
1月前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
113 67
|
5天前
|
算法 安全 Go
Go语言中的加密和解密是如何实现的?
Go语言通过标准库中的`crypto`包提供丰富的加密和解密功能,包括对称加密(如AES)、非对称加密(如RSA、ECDSA)及散列函数(如SHA256)。`encoding/base64`包则用于Base64编码与解码。开发者可根据需求选择合适的算法和密钥,使用这些包进行加密操作。示例代码展示了如何使用`crypto/aes`包实现对称加密。加密和解密操作涉及敏感数据处理,需格外注意安全性。
29 14
|
5天前
|
Go 数据库
Go语言中的包(package)是如何组织的?
在Go语言中,包是代码组织和管理的基本单元,用于集合相关函数、类型和变量,便于复用和维护。包通过目录结构、文件命名、初始化函数(`init`)及导出规则来管理命名空间和依赖关系。合理的包组织能提高代码的可读性、可维护性和可复用性,减少耦合度。例如,`stringutils`包提供字符串处理函数,主程序导入使用这些函数,使代码结构清晰易懂。
38 11
|
5天前
|
存储 安全 Go
Go语言中的map数据结构是如何实现的?
Go 语言中的 `map` 是基于哈希表实现的键值对数据结构,支持快速查找、插入和删除操作。其原理涉及哈希函数、桶(Bucket)、动态扩容和哈希冲突处理等关键机制,平均时间复杂度为 O(1)。为了确保线程安全,Go 提供了 `sync.Map` 类型,通过分段锁实现并发访问的安全性。示例代码展示了如何使用自定义结构体和切片模拟 `map` 功能,以及如何使用 `sync.Map` 进行线程安全的操作。
|
9天前
|
监控 安全 算法
深度剖析核心科技:Go 语言赋能局域网管理监控软件进阶之旅
在局域网管理监控中,跳表作为一种高效的数据结构,能显著提升流量索引和查询效率。基于Go语言的跳表实现,通过随机化索引层生成、插入和搜索功能,在高并发场景下展现卓越性能。跳表将查询时间复杂度优化至O(log n),助力实时监控异常流量,保障网络安全与稳定。示例代码展示了其在实际应用中的精妙之处。
34 9
|
19天前
|
算法 安全 Go
Go 语言中实现 RSA 加解密、签名验证算法
随着互联网的发展,安全需求日益增长。非对称加密算法RSA成为密码学中的重要代表。本文介绍如何使用Go语言和[forgoer/openssl](https://github.com/forgoer/openssl)库简化RSA加解密操作,包括秘钥生成、加解密及签名验证。该库还支持AES、DES等常用算法,安装简便,代码示例清晰易懂。
52 12