zoukankan      html  css  js  c++  java
  • 关于go切片的理解

    package main
    
    import "fmt"
    
    func main() {
    
    	arr := [...]int{1, 3, 5, 7, 9, 11}  // arr 是一个数组
    	s1 := arr[:]
    	// 数组是连续存储的空间  切片只存放指针 没有存放数据  所以 指针的位置
    	// 只收上界影响,也就是数据的基址, 他的操作范围 只能从指针开始到连续的内存结束 如果超过容量 扩容后
    	// 就产生了新的数组和内存空间 切片的指针也会指向新的内存
    
    	fmt.Println(&s1[0])
    	fmt.Println(&arr[0])  //打印基址(也就是第一个元素的地址),结果是一样的,因为都共用同一份内存数据。空切片的地址是0x0 
    
    	s1 = s1[:1]
    	fmt.Println(&s1[0])
    	fmt.Println(&arr[0])  //修改s1的len,打印基址,结果是一样的,因为都共用同一份内存数据,且基址是同一个元素地址。
    	s1 = s1[:2]
    	fmt.Println(s1)//增加s1的len,可以打印出{1,3} ,说明切片的数据是基于arr数组,本身不保存数据,取决于当前指针的位置,
    	// 以及指针之后的,对应的arr数组的连续内存地址的值。
    
    	s1 = s1[1:3]
    	fmt.Println(&s1[0])  //左界右移1,长度2,容量5,基址变化右移1
    	fmt.Println(s1) //对应的数据,也是从基址开始的2个元素
    
    	s1 = s1[0:5]
    	fmt.Println(s1)  //长度增加,容量5,所以,是可以打印出5个元素
    }
    

      

    暗夜之中,才见繁星;危机之下,暗藏转机;事在人为,为者常成。
  • 相关阅读:
    打印出从1到最大的n位十进制数
    排序算法--(二)
    排序算法 (-)
    两个栈实现一个队列
    C++ 模板类解析
    根据先序遍历中序遍历重建二叉树
    格式化时间
    用js实现冒泡排序
    接口和抽象类的区别
    解析json
  • 原文地址:https://www.cnblogs.com/zenghansen/p/15617521.html
Copyright © 2011-2022 走看看