golang中的数组与切片

golang中,当用数组去初始化一个切片时,数组的地址即为&slice[0],例子如下:

package main

import (
	"fmt"
	"math/rand"
	"net"
	"os"
	"time"
	"unsafe"
)

func main() {
	for {
		pcRecvMag()
		time.Sleep(time.Second)
	}
}

func pcRecvMag() {
	var buf [20]byte
	readFromUDP(buf[0:])
	pcHandleMsg(&buf)
}

func pcHandleMsg(p2byteArray *[20]byte) {
	fmt.Printf("byteArray pointer:%v\n",unsafe.Pointer(p2byteArray))
	fmt.Println(*p2byteArray)
}

func readFromUDP(b []byte) {
	b[0] = (byte)(rand.Intn(255))
	b[1] = (byte)(rand.Intn(255))
	fmt.Printf("len:%d,cap:%d\n",len(b),cap(b))
	fmt.Printf("slice0 pointer:%v\n",&b[0])
}
输出结果:

len:20,cap:20

slice0 pointer:0x115ad940

byteArray pointer:0x115ad940

[86 132 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]

len:20,cap:20

slice0 pointer:0x1157a340

byteArray pointer:0x1157a340

[122 254 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]

len:20,cap:20

slice0 pointer:0x115ad9e0

byteArray pointer:0x115ad9e0

[151 153 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]


这一点可以用slice的数据结构来解释,如下图所示:

这个是slice的数据结构,它很简单,一个指向真实array地址的指针ptr,slice的长度len和容量cap。


相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...