Golang 数组与切片

2024-06-12 15:58
文章标签 golang 切片 数组

本文主要是介绍Golang 数组与切片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

好的代码会说话,见码

// 数组
// 按值传递的(即是传递的副本,定长
// [length]Type
// [N]Type{value1, value2, ..., valueN}
// [...]Type{value1, value2, ..., valueN}//  切片
// 引用类型,不定长
// 会创建一个隐藏的初始化为零值的数组,返回一个引用该隐藏数组的切片// make([ ]Type, length, capacity)
// make([ ]Type, length)
// [ ]Type{}
// [ ]Type{value1, value2, ..., valueN}package mainimport ("fmt"
)func main() {// 定义go数组,值传递// 省略号语法(go语言自动计算数组长度)a := [...]int{1, 2, 3, 4, 5, 6, 7}fmt.Printf("数组%v 的长度和容量是: %d 和 %d \n", a, len(a), cap(a))fmt.Printf("数组%v 中的项是:", a)// for ... range 迭代数组列表for _, value := range a {fmt.Printf("%d ", value)}fmt.Println()s1 := a[3:6]fmt.Printf("切片%v 的长度和容量是: %d 和 %d \n", s1, len(s1), cap(s1))fmt.Printf("在切片内的项: %v 是:", s1)for _, value := range s1 {fmt.Printf("%d ", value)}fmt.Println()s1[0] = 456fmt.Printf("改变切片后的数组项是:%v", s1)fmt.Println()for _, value := range a {fmt.Printf("% d", value)}fmt.Println()s2 := make([]int, 10, 20)s2[4] = 5fmt.Printf("切片 %v is: %d and %d\n", s2, len(s2), cap(s2))fmt.Printf("在切片 %v 项是:", s2)for _, value := range s2 {fmt.Printf("% d", value)}fmt.Println()}

结果

数组[1 2 3 4 5 6 7] 的长度和容量是: 7 和 7 
数组[1 2 3 4 5 6 7] 中的项是:1 2 3 4 5 6 7 
切片[4 5 6] 的长度和容量是: 3 和 4 
在切片内的项: [4 5 6] 是:4 5 6 
改变切片后的数组项是:[456 5 6]1 2 3 456 5 6 7
切片值: [0 0 0 0 5 0 0 0 0 0] is: 10 and 20
在切片 [0 0 0 0 5 0 0 0 0 0] 项是: 0 0 0 0 5 0 0 0 0 0

这篇关于Golang 数组与切片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1054670

相关文章

剑指offer(C++)--数组中只出现一次的数字

题目 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 class Solution {public:void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {int len = data.size();if(len<2)return;int one = 0;for(int i

IOS 数组去重的几种方式

本来只知道NSSet和KeyValues的。今天又新学了几种方式 还有就是和同事学的一种方式 外层循环从0开始遍历,内层从最后一个元素开始遍历 for(int i=0;i<index;i++){  for(int j=index-1;j>i;j-- ){ } }

想让Python序列切片更高效?这些技巧你不可不知!

目录 1、自定义类实现切片 🍏 1.1 实现__getitem__方法 1.2 支持正负索引与步长 2、利用 collections.abc 模块 🧠 2.1 继承MutableSequence类 2.2 重写关键方法 3、使用标准库itertools.slice 🍲 3.1 itertools工具介绍 3.2 slice函数应用实例 4、通过生成器实现动态切片 🌀

Java基础(二)——数组,方法,方法重载

个人简介 👀个人主页: 前端杂货铺 ⚡开源项目: rich-vue3 (基于 Vue3 + TS + Pinia + Element Plus + Spring全家桶 + MySQL) 🙋‍♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步至千里,积小流成江海 🥇推荐学习:🍖开源 rich-vue3 🍍前端面试

Sharding(切片)技术(解决数据库分库一致性问题)

Sharding(切片) 不是一门新技术,而是一个相对简朴的软件理念,就是当我们的数据库单机无法承受高强度的i/o时,我们就考虑利用 sharding 来把这种读写压力分散到各个主机上去。 所以Sharding 不是一个某个特定数据库软件附属的功能,而是在具体技术细节之上的抽象处理,是Horizontal Partitioning 水平扩展(或横向扩展)的解决方案,其主要目的是为突破单节点数

poj 3882(Stammering Aliens) 后缀数组 或者 hash

后缀数组:  构建后缀数组,注意要在字符串莫末尾加上一个没出现过的字符。然后可以2分或者直接扫描,直接扫描需要用单调队列来维护 VIEW CODE #include<cstdio>#include<algorithm>#include<iostream>#include<cmath>#include<queue>#include<stack>#include<string

poj 3294(Life Forms) 2分+ 后缀数组

我曾用字符串hash写,但是超时了。只能用后最数组了。大致思路:用不同的符号吧字符串连接起来,构建后缀数组,然后2分答案,依次扫描后缀数组,看是否瞒住条件。 VIEW CODE #include<cstdio>#include<vector>#include<cmath>#include<algorithm>#include<cstring>#include<cassert>#

C语言函数参数--数组长度

int read_column_numbers(int columns[], int max){} 在函数声明的数组参数中,并未指定数组的长度。这种格式是OK的,因为无论调用函数的程序传递给它的数组参数的长度是多少,这个函数都将照收不误。 这是一个伟大的特性,它允许单个函数操纵任意长度的一维数组。 这个特性不利的一面是函数没法知道该数组的长度。如果确实需要数组的长度,它的值必须作为一个单独的

从JavaScript 数组去重看兼容性问题,及性能优化(摘自玉伯博客)

缘由 JavaScript 数组去重经常出现在前端招聘的笔试题里,比如: 有数组 var arr = ['a', 'b', 'c', '1', 0, 'c', 1, '', 1, 0],请用 JavaScript 实现去重函数 unqiue,使得 unique(arr) 返回 ['a', 'b', 'c', '1', 0, 1, ''] 作为笔试题,考点有二: 正确。别小看这个考点

用Ps将PSD切片并将切片保存为透明背景的图片

第一步:选择放大镜工具或者Ctrl++将要切片的部分放大。 第二步:选择移动工具单击要切片的部分,在右边的图层栏找到要切片的图层在文字上右键选择转换为智能对象,再右键该图层的文字选择栅格化图层。 第三步:单击选中所要切片的部分,然后Ctrl+A、Ctrl+C、Ctrl+N(背景内容选择透明)、Ctrl+V、Ctrl+S(将文件保存为PNG格式),这样就可以得到透明背景的图片了!