zoukankan      html  css  js  c++  java
  • go语言中的slice

    package main;
    
    import "fmt"
    
    func main() {
    	//slice本身不是数组,指向底层的数组
    	//作为变长数组的替换方案
    	//slice是引用类型
    
    	//声明一个slice,这里不需要指定长度
    	var a []int;
    
    	//创建一个数组
    	var b = [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
    
    	//通过数组来创建slice
    	c := b[1:len(b)];
    	//同上,简写
    	d := b[1:];
    	//从下标2开始,到4结束,不包括下标4的元素
    	e := b[2:4];
    	//从数组开始,取3个
    	f := b[:3];
    
    	//通过make创建slice
    	//长度为3,容量为10的slice
    	g := make([]int, 3, 10);
    
    	h := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g'};
    	i := h[2:5];
    	//注意这里的索引是相对i的索引,i现在是['c', 'd', 'e']
    	j := i[1:3];
    	//注意这里6已经超过了i的cap容量,会报错
    	//j := i[1:6];
    
    	//在slice的尾部追加元素
    	k := make([]int, 3, 6);
    	fmt.Printf("%p %v
    ", &k, k);
    	k = append(k, 1, 2, 3);
    	fmt.Printf("%p %v
    ", &k, k);
    	//这里当追加的元素超过了slice的cap时,会重新分配地址,并把值拷贝
    	k = append(k, 4, 5, 6);
    	fmt.Printf("%p %v
    ", &k, k);
    
    	//slice是引用类型,修改某一个slice的值,其他也相应改变
    	m := []int{1, 2, 3, 4, 5};
    	l := m[2:5];
    	n := m[1:4];
    	fmt.Println(m, l, n);
    	//改变l中的值,m,n中也相应改变
    	l[0] = 6;
    	fmt.Println(m, l, n);
    
    	//如果当slice发生地址重新分配后,那相应改变是不生效的
    	o := []int{1, 2, 3, 4, 5};
    	p := o[2:5];
    	q := o[1:4];
    	fmt.Println(o, p, q);
    	//在改变p元素值之前,我们让q发生地址重新分配
    	q = append(q, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1);
    	//再改变p的值,这时q的值不会发生改变,因为它已经指向新的地址
    	p[0] = 6;
    	fmt.Println(o, p, q);
    
    	//copy时以长度短的为准
    	r := []int{1, 2, 3, 4, 5};
    	s := []int{6, 7, 8};
    	//这里只会把s中的6,7,8拷贝到r中的1,2,3
    	copy(r, s);
    	fmt.Println(r, s);
    
    	fmt.Println(a);
    	fmt.Println(b);
    	fmt.Println(c);
    	fmt.Println(d);
    	fmt.Println(e);
    	fmt.Println(f);
    	fmt.Println(g, len(g), cap(g));
    	fmt.Println(string(h));
    	fmt.Println(string(i), cap(i));
    	fmt.Println(string(j), cap(j));
    }
    

      

  • 相关阅读:
    实战分享 | 你知道这个死锁是怎么产生的吗?
    HDU 3016 线段树区间更新+spfa
    POJ 2828 线段树(想法)
    POJ 2184 01背包+负数处理
    HDU 2955 01背包(思维)
    HDU 1171 背包
    HDU 1561 树形DP入门
    POJ 3694 tarjan 桥+lca
    POJ 2446 最小点覆盖
    POJ 2226 最小点覆盖(经典建图)
  • 原文地址:https://www.cnblogs.com/jkko123/p/6797277.html
Copyright © 2011-2022 走看看