golang高频面试真题
⚡根据真实面试经历,筛选收集各公司岗位面试过程中涉及的《GOLANG高频面试真题》
channel和锁的对比
答案1:
并发问题可以用channel解决也可以用Mutex解决,但是它们的擅长解决的问题有一些不同。
channel关注的是并发问题的数据流动,适用于数据在多个协程中流动的场景。
而mutex关注的是是数据不动,某段时间只给一个协程访问数据的权限,适用于数据位置固定的场景。
channel的应用场景
答案1:
channel适用于数据在多个协程中流动的场景,有很多实际应用:
① 任务定时
比如超时处理:
select {
case <-time.After(time.Second):
定时任务
select {
case <- time.Tick(time.Second)
② 解耦生产者和消费者
可以将生产者和消费者解耦出来,生产者只需要往channel发送数据,而消费者只管从channel中获取数据。
③ 控制并发数
以爬虫为例,比如需要爬取1w条数据,需要并发爬取以提高效率,但并发量又不过过大,可以通过channel来控制并发规模,比如同时支持5个并发任务:
ch := make(chan int, 5)
for _, url := range urls {
go func() {
ch <- 1
worker(url)
<- ch
}
}
slice和array区别
答案1:
array是固定长度的数组,是值类型的,如果进行赋值或者作为函数参数,实际上整个数据都会被重新拷贝一份。
使用前必须声明长度
arr := [5]int
而slice属于引用类型,是一个不定长的,总是指向底层的数组array的数据结构。作为函数参数时,slice传递的是指针。
创建时不需要指定长度 var s []int
s := make([]int,10)
s :=[]int{1,2,3}