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

专业做能源招聘的网站成都广告公司贺忠阳简历

专业做能源招聘的网站,成都广告公司贺忠阳简历,在哪些网站可以做企业名称预审,字体怎么网wordpress每日八股-5.31 Go1.切片是值传递还是引用传递?2.切片的深拷贝与浅拷贝3.切片的底层实现4.切片的扩容机制5.Map是线程安全的吗?6.哪些类型可以作为map的key?7.Map删除一个key内存是否会释放?8.Map为什么是无序的?9.如何…

每日八股-5.31

  • Go
    • 1.切片是值传递还是引用传递?
    • 2.切片的深拷贝与浅拷贝
    • 3.切片的底层实现
    • 4.切片的扩容机制
    • 5.Map是线程安全的吗?
    • 6.哪些类型可以作为map的key?
    • 7.Map删除一个key内存是否会释放?
    • 8.Map为什么是无序的?
    • 9.如何顺序读写map?
    • 10.Map的底层实现
    • 11.Struct是否可以进行比较
    • 12.Rune和Byte的区别

Go

1.切片是值传递还是引用传递?

在go语言中,所有的传参都是值传递,切片也不例外,但切片是引用类型,因为切片的底层实现包括一个指针,用来指向当前数组的起始位置,长度,以及容量;当在函数内部对切片进行修改时,外部的切片也会受到影响;而在函数内部使用append增加元素时,外部的元素不会受到影响,所以说我们在实践中都是让append后的切片赋值给原切片。

补充:
引用类型:slice、map、channel、pointer
非引用类型:int、string、struct

2.切片的深拷贝与浅拷贝

假设我们现在有一个切片s1,如果用:=的形式让s2:=s1,那么这就是浅拷贝,他们的指针指向同一个地址,修改任意一个都会影响另一个,如果说我们用copy()的话,那么s1和s2底层的指针指向两个完全不同的地址,修改一个对另一个不会造成任何影响,这就是深拷贝。

3.切片的底层实现

切片的数据结构是一个结构体,包括三个参数Pointer,len,cap
其中Pointer指向数组中要表示的片段的起始元素;
len表示当前切片包含多少个元素;
cap表示当前切片最大可以容纳多少个元素;

type slice struct {array unsafe.Pointerlen   intcap   int
}

4.切片的扩容机制

go1.18之后的扩容机制,有一个阈值256
如果当前要扩容的容量大于旧容量的2倍,那么直接扩容为新的容量
如果当前要扩容的容量小于阈值,那么扩容为旧容量的二倍
如果当前要扩容的容量大于阈值,那么新容量为旧容量加上(旧容量加三倍的阈值)/4
在这里插入图片描述

5.Map是线程安全的吗?

线程安全指的是在并发场景或多个goroutine同时操作一个对象,执行的结果依然是正确的。对于map来说,并发读是安全的,但是并发读写是不安全的,会造成不可预测的结果,程序会抛出fatal Error:concurrent map write

6.哪些类型可以作为map的key?

只要是可比较的类型都可以作为map的key,比如int,string,bool,interface,struct,指针,channel等,不可比较的类型就无法作为map的key,比如slice,map,函数。

但是如果interface或struct里包括了不可比较的类型,那么也不能作为map的key
channel和指针是可比较的引用类型(和前面提到的引用类型非引用类型对比记忆)

7.Map删除一个key内存是否会释放?

Map删除一个key后,对应的key-value将不复存在,但对应的内存不会立即释放,会有GC(垃圾回收器)负责释放这部分内存。如果没有别的对象引用该value,这部分内存最终会由GC释放。

8.Map为什么是无序的?

因为在go的底层map的实现是一个哈希表,当要往map里面存储新的元素时,会为每一个键计算一个哈希值,而这个哈希值在内存中不一定是连续的;另外当map进行扩容时,所有在map中存储的元素都会重新计算一遍哈希值,所以多次遍历同一个map,结果不一定是相同的。

9.如何顺序读写map?

创建一个切片,遍历map的时候把键存储到切片中,然后对该切片进行排序,遍历该切片,就可以实现顺序输出map。

10.Map的底层实现

type hmap struct {count      int            // 元素个数,调用len(map)返回这个值B          uint8          // bucket数量是2^Bhash0      uint32         // hash seed,用于在计算哈希值时引入随机性buckets    unsafe.Pointer // 指向bucket数组的指针(存储key val);大小:2^Boldbuckets unsafe.Pointer // 扩容时,buckets 长度是 oldbuckets 的两倍// ...
}
type bmap struct {topbits  [8]uint8     // 这是一个长度为8的字节数组。对于存储在桶中的每个键,它会保存该键哈希值的高8位(top hash bits)。这是一种优化,可以在查找时快速比较,而不用立即比较完整的键,从而提高效率keys     [8]keytype   // 存储key的数组values   [8]valuetype // 存储val的数组overflow uintptr      // 指向“溢出桶”的指针。如果一个桶存满了8个键值对,后续哈希到这个桶的新键值对就会存放到溢出桶中
}

11.Struct是否可以进行比较

只要结构体内的数据类型是可以比较的,那么结构体就可以进行比较。可比较的数据类型包括基本数据类型(如int,float,string)和指针、channel等,可以使用reflect.DeepEqual()来对两个结构体进行比较,该结构体会递归的比较结构体内部的数据类型。

12.Rune和Byte的区别

rune和byte都是go语言中的字符类型,总的来说就是rune表示的范围更大。byte其实是uint8类型,它用来表示单个ascii码字符;rune是int32类型,它可以用来表示unicode字符或者utf-8字符,如果我们需要切割的字符串中有中文,我们需要把它转化为[]rune数组,而不是[]byte数组

package mainimport "fmt"func main() {strs := "go语言"fmt.Println(string([]byte(strs)[0:3])) // 输出:go�fmt.Println(string([]rune(strs)[0:3])) // 输出:go语
}
http://www.dtcms.com/wzjs/819605.html

相关文章:

  • 博物馆网站模版运维工程师累吗
  • wordpress搭建短视频网站注册一个公司需要多久
  • 如何建立自己的个人网站寻找南京帮助做网站的单位
  • 英文购物网站模板联想公司网站建设现状
  • 微网站技术印度外贸网站有哪些
  • 网站营销最大的特点企业服务公司起名
  • 山东省建设执业注册中心网站最开放的浏览器下载
  • 网易云音乐网站开发介绍怎么用云服务器做网站
  • 郑州惠济区建设局网站网站建设 ader
  • 查企业数据要去什么网站快递加盟代理
  • 手机版网站建站做货代的要注册哪种物流网站
  • 汽车之家网站开发方案百度指数查询工具
  • 自己建设网站怎么被百度收入为什么要建设种苗供求网站
  • 四川住房建设和城乡建设厅网站政协门户网站建设
  • 网站安全风险评估报告贵阳有哪些可以制作网站的公司吗
  • 泰安网络推广培训广州seo优化方法
  • 淘宝客源码程序 爱淘宝风格+程序自动采集商品 淘宝客网站模板h5企业网站定制排名
  • 公司注册网站系统网站 栏目做下拉
  • 广东建设工程监理检测协会网站chrome官方下载
  • 安徽福凯建设集团网站ui设计较好的网站
  • 太原广告公司网站建设做移动网站快速
  • 上海建站网络科技在百度上做购物网站
  • 江西网站开发哪家好做网站的公司哪家好一点
  • 网站建设优化文档在深圳市住房和建设局网站
  • 西安保洁公司网站建设上海做网站的公司哪个好
  • 网站建设的发展历程青海做网站多少钱
  • 在哪里推广网站单页面推广网站
  • 深圳网站建设公司收费大连海外网站建设
  • 网站建设背景介绍商城网站建设定制网站建设
  • 好用的建站系统长春做网站的公司哪家好