golang面试题

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}

相关推荐
没有梦想的咸鱼185-1037-166317 分钟前
基于R语言机器学习方法在生态经济学领域中的实践技术应用
开发语言·机器学习·数据分析·r语言
考虑考虑22 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
Chan1634 分钟前
【智能协同云图库】基于统一接口架构构建多维度分析功能、结合 ECharts 可视化与权限校验实现用户 / 管理员图库统计、通过 SQL 优化与流式处理提升数据
java·spring boot·后端·sql·spring·intellij-idea·echarts
向上的车轮41 分钟前
基于go语言的云原生TodoList Demo 项目,验证云原生核心特性
开发语言·云原生·golang
The Chosen One98543 分钟前
C++ : AVL树-详解
开发语言·c++
PH_modest1 小时前
【Qt跬步积累】—— 初识Qt
开发语言·qt
库库林_沙琪马1 小时前
REST接口幂等设计深度解析
spring boot·后端
IT_陈寒1 小时前
Redis性能提升50%的7个关键优化策略,90%开发者都不知道第5点!
前端·人工智能·后端
智商偏低1 小时前
ASP.NET Core 身份验证概述
后端·asp.net
冷冷的菜哥1 小时前
ASP.NET Core使用MailKit发送邮件
后端·c#·asp.net·发送邮件·mailkit