golang中数组array和切片slice的区别

go语言中最常用的数据结构 数组array 和 切片 slice的区别对比:

定义和初始化

数组: [size]类型 切片: []类型 , 数组变量[low:high]

Go 复制代码
	var arr1 = [3]string{"a", "b", "c"} // 数组array定义和初始化
	fmt.Printf("arr1数据类型: %v Type: %T\n", reflect.ValueOf(arr1).Kind(), arr1)
	//arr1数据类型: array Type: [3]string

	var s1 = []string{"a", "b", "c"} // 切片slice定义和初始化
	fmt.Printf("s1数据类型: %v Type: %T\n", reflect.ValueOf(s1).Kind(), s1)
	//s1数据类型: slice Type: []string

	s2 := arr1[0:2] // 从数组arr1中通过指定下标和上标截取
	fmt.Printf("s2数据类型: %v Type: %T\n", reflect.ValueOf(s2).Kind(), s2)
	// s2数据类型: slice Type: []string

区别

  1. 定义的方式不同,切片可以指定定义和初始化,也可以从数组中截取;
  2. 数组定义后大小不可修改;
  3. 切片的大小可以通过 append()函数修改大小;
  4. 切片的长度可以在运行时修改,最小为 0 最大为相关数组的长度;
  5. 切片是一个 长度可变的数组
  6. 数据类型不一样,array是值类型【 变量直接存储值 通常在栈中分配内存**】, slice是引用类型【** 变量存储的是一个地址,内存通常在堆上分配**】,引用类型** 不需要使用额外的内存并且比使用数组更有效率

相同点

  1. 数据的访问和修改都可以通过 变量名[下标] 的方式获取和修改;
  2. 都可以使用函数 len()获取长度, cap()获取容量;
  3. ......
相关推荐
悟空码字几秒前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常10 分钟前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强11 分钟前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端
小码哥_常39 分钟前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌1 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
None3211 小时前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js
初次攀爬者1 小时前
Kafka + KRaft模式架构基础介绍
后端·kafka
洛森唛1 小时前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch
拳打南山敬老院2 小时前
Context 不是压缩出来的,而是设计出来的
前端·后端·aigc
初次攀爬者2 小时前
Kafka + ZooKeeper架构基础介绍
后端·zookeeper·kafka