当前位置: 首页 > news >正文

西安专业承接网站搭建模板织梦网站产品

西安专业承接网站搭建模板,织梦网站产品,上海网站建设服务市价,跨境电商免费开店的有哪些做了五年的go开发#xff0c;却并没有什么成长#xff0c;都停留在了业务层面了。一直以为golang中函数传参#xff0c;如果传的是引用类型#xff0c;则是以引用传递#xff0c;造成这样的误解#xff0c;实在也不能怪我。我们来看一个例子#xff0c;众所周知#xf…做了五年的go开发却并没有什么成长都停留在了业务层面了。一直以为golang中函数传参如果传的是引用类型则是以引用传递造成这样的误解实在也不能怪我。我们来看一个例子众所周知slice是个引用类型我们以slice为例。 package main ​ import fmt ​ func main() {strSlice : make([]string, 0,10)strSlice append(strSlice, 初始值)//打印一下没有在函数内部修改的初始情况fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0])//在函数内部修改初始slice内容再打印change(strSlice)fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0]) } func change(str []string){fmt.Println(函数传参地址,str[0])str[0]改掉这个内容 } 猜猜打印出来的会是什么结果 ​不管你是怎么看如果只有这么一个案例就很容易产生误解。打印的函数参数的地址和外部slice的地址是一致并且在函数体内修改的值的确影响了slice的值由此现象很容易得出是引用传递。 事实果真如此么我们再来看一个案例。 package main ​ import fmt ​ func main() {strSlice : make([]string, 0,10)strSlice append(strSlice, 初始值)//打印一下没有在函数内部修改的初始情况fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0])//在函数内部修改初始slice内容再打印change(strSlice)fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0]) } func change(str []string){fmt.Println(函数传参地址,str[0])strappend(str,新增一个内容) } 如果是引用传递那么经过change函数追加了值的strSlice应该是能打印出追加的值。好了我们直接看结果。 结果很是出乎我的意料之外啊竟然不是像我上面猜想的那样。由此至少可以得出一个结论golang中函数的参数传递不是引用传递。那么也就是说即使参数是引用类型也是值传递既然是值传递第一个案例作何理解呢第二个案例又如何理解呢 我们看一下slice的底层结构。 //go 1.20.3 path: /src/runtime/slice.go type slice struct {array unsafe.Pointerlen intcap int } array 是一个指向底层数组的指针这个数组存储着切片中的元素。len 表示切片的长度即切片中元素的数量。cap 表示切片的容量即切片底层数组中可用的元素数量。golang的函数传参都是值传递即使传递的是引用类型也是对应引用类型的地址拷贝。因此第一个案例中实际上是把指向底层数组的指针的地址拷贝生成一个副本传到了函数体中所以第一个案例中修改了0xc00006c0a0地址里的内容会引发外面的参数发生变化。这个我们可以做个案例测试一下。 package main ​ import fmt ​ func main() {strSlice : make([]string, 0,10)strSlice append(strSlice, 初始值)//打印一下没有在函数内部修改的初始情况fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0])//在函数内部修改初始slice内容再打印change(strSlice)fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0]) } func change(str []string){fmt.Println(函数传参地址,str[0])for i:0;i10;i{str append(str, fmt.Sprint(i))}fmt.Println(扩容之后的地址,str[0])str[0]改掉这个内容 } 我们知道当slice发生扩容runtime会开辟一块新的内存地址把内容拷贝到新的地址指向的内存中那么我们可以测试一下当slice发生扩容再修改内容就不会影响原来的参数。 ​实际结果验证了我们的猜想扩容之后开辟新的内存地址来存放内容因此再修改这个参数也不会影响外部参数。 可是这个依然没有解除掉第二个案例——没有扩容时函数内append之后外部参数打印结果和预期不符的疑惑。实际上并不矛盾因为slice结构中有一个变量len,这个表示slice中元素的数量用大白话来理解就是可见的元素传参的过程中不仅拷贝了地址还拷贝了len和cap因此虽然形参中的len发生了变化但是并不影响实参的len。画个内存示意图来理解一下。 package main ​ import fmt ​ func main() {strSlice : make([]string, 0,10)strSlice append(strSlice, 初始值)//打印一下没有在函数内部修改的初始情况fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0],len,len(strSlice))//在函数内部修改初始slice内容再打印change(strSlice)fmt.Println(strSlice:,strSlice,strSlice地址,strSlice[0],len,len(strSlice)) } func change(str []string){fmt.Println(函数传参地址,str[0])strappend(str,新增一个内容)fmt.Println(形参str长度:,len(str)) } 直接看结果果然验证了我们上面的猜想。 至此函数值传递的探究到此结束。
http://www.tj-hxxt.cn/news/231558.html

相关文章:

  • 电子商务网站建设用什么登录网络规划设计师教程(第2版)
  • 南通网站建设top自己可以免费做网站吗
  • 网站开发及流行框架thinkphpcmf网站开发
  • 网站设计构想为网站网站做宣传
  • 长沙商城网站建设有趣的个人网站
  • 自己怎么做直播网站吗用电脑做网站服务器
  • 做中医诊所网站百度不喜欢wordpress
  • 空白网站怎么建百度做的网站后台怎么更新
  • 免费的网站推广渠道响应式网站企业
  • 山东济南seo整站优化费用网站推广风险
  • 门户网站产品设计方案策划书模板范文
  • 岫岩做网站微信公众号开发教程
  • 怎么做微信钓鱼网站吗电子商务推广方式有哪些
  • 湛江城市建设培训中心网站网页设计课程安排
  • 微网站设计与制作流动性管理
  • 郑州百度网站优化排名网络品牌推广策略
  • 网站建设业务流程做网站怎样申请域名
  • 洛阳网站建设价格低如何利用国外的网站开发客户
  • .net开发网站怎么样上海外贸新三样出口超2400亿元
  • 网站服务器租用售价网站推广培训哪里好
  • 宁夏建设银行网站苏州seo外包
  • 民营建筑网站军事新闻头条最新军情
  • 合肥网站搜索优化学生模拟网站开发
  • 网站定制报价表培训课程网站
  • 重庆建设厅的网站首页如何建设公司的网站首页
  • 用图片做简单网站c2c网站的类型
  • 网站建设的经营范围dw网页制作教程完整版
  • 在线建设房屋设计网站济南正规网站制作怎么选择
  • 宝塔网站建设跳转微信可打开重庆网站建设怎么样
  • 四方区企业型网站建设网站网站开发建设