那位拿了多个Offer的大佬分享了最新Go面经

2024-03-26 17:52

本文主要是介绍那位拿了多个Offer的大佬分享了最新Go面经,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

和大家分享一下我们 Go就业训练营 和 升职加薪星球 中战友们投稿的真实面经。

这是第一篇,计划还会再更新4篇最新Go面经,都是拿到Offer的那种!

欢迎大家关注我的账号,关注之后不迷路。

先秀战绩

虽然不同的公司考察的侧重点不一样,但是咱们还是可以有针对性做准备。大佬说到:

经过这么多场面试发现:如果面试官对项目感兴趣项目就拷打的比较深(我觉得还比较easy);如果面试官对项目没兴趣就深挖知识点,拷打算法。(墙裂建议大家写好项目介绍!)

b站外包

  1. 旋转数组

  2. mysql索引相关。

  • B+树有什么特点?
  • 为什么不用B树(查询的速度差不多,因为b+树数据都在叶子节点)。
  • 非聚簇索引和聚簇索引的区别。
  • 索引为什么要用id不用字符
  1. Linux相关命令和场景

  2. docker和k8s

上海莹锴网络科技

  1. Kafka怎么保证消息不丢失

  2. Kafka里面生产者给broker应答给生产者的时候网络断了该怎么处理?

  3. 讲一下golang中的并发编程

梭翱信息技术

  1. go语言特性(channel、map考察)

  2. 讲一下waitgroup的使用

  3. 知道模块化缓存吗?

  4. 知道分级缓存吗?

主要是一些缓存的应用场景为主。对于一些技术(redis、mq)的应用场景这部分比较欠缺

矢安科技

  1. 哪些数据结构是线程不安全的

  2. Map为什么是线程不安全的

  3. Channel阻塞可以实现什么场景(计数,令牌桶)

  4. Mysql什么时候是行所什么时候是表锁

  5. Mysql有几种错误读(脏读、幻读等等)

  6. Mysql默认事务隔离级别是什么

  7. 假如有个sql联了多个表还有字查询,改怎么优化

  8. 你平常是怎么优化mysql的

  9. Kafka为什么快?

  10. Kafka怎么实现消息不丢失

  11. Kafka是顺序写还是随机写

  12. Go协程是怎么扩展内存的(找P要)

  13. 讲一下你对docker和k8s的理解

  14. 说一下某种集群的leader选举策略(举例了redis)

  15. Redis中什么是主管下线,什么是客观下线。

  16. 聊一聊你对GRPC的理解。

  17. 为什么gprc传输比JSON快

  • 少了json转为2进制

  • protobuf文件中字段名用后面的数字代替,进一步减少数据量(学到了)

场景题:

  1. 假如有大量定时任务需要在凌晨1点都准时开始执行,你会怎么做

  2. 假如消息发送过多导致大量堆积怎么处理

华苏科技(国家电网外包)

项目拷打(介绍项目+遇到的难题)

  1. 有缓冲channel和无缓冲channel的区别

  2. 了解gin的中间件吗,讲一下你对他的了解

  3. select 满足多个case的时候怎么执行的。

  4. 如果有一个全局变量怎么保证并发安全。

  5. CPU高问题如何解决?

  6. 知道哪些设计模式?

场景题:

我有一个方法,用来存储一些文件资源,有多种不同的存储方式,你会怎么设计这个方法(应该是要考察泛型的使用)

爱可生

面试官说是go开发,但是没有什么技术原理提问。

介绍简历中的项目。

  1. 遇到的项目场景难题。

(他不太想听那种用技术选型方案来解决的常规问题,吹了一下systemtap)

  1. 讲一个技术栈中随便一个技术遇到的难题。

  2. 平时是怎么学习的。

整个面试几乎就没有技术性提问,一直在让我介绍项目,和遇到的问题以及我是怎么解决的,解决的思路是什么。

特斯拉外包笔试

题1

题2

题3

最后一道sql没写出来。但是前两题自测都对

成都美大

项目拷打

  1. 讲一下mysql的索引是什么结构

  2. 讲一下sql一般是怎么优化的

  3. Kafka消息堆积怎么处理

  4. 写一个方法的时候是传值好还是结构体好

场景题:

秒杀超卖怎么解决。(分布式锁+redis缓存)

矢安科技二面

一面的技术leader,没有聊太多的技术话题。主要是一些团队协作沟通上的问题

  1. 假如产品给你一个需求,你觉得不合适,和产品经理有冲突,你会怎么做?

  2. 你平时是怎么学习的?

  3. 假如给你一个活要求某个时间内快速完成,你又没学过,你会怎么做?

试探你是不是愿意加班

七云网络

笔试

三道程序解答题:

题1

问1

先输出哪个?

题2

问2

输出什么?

题3

问3

这段代码有什么问题?

问答题:

  1. TCP和http的关系是什么?

  2. 伪代码描述一下乐观锁

  3. Linux怎么看磁盘占用?

  4. 描述一下GC的过程?

  5. SQL题:写出薪资第二高的薪资

表emp

id int

salary int

算法:

力扣 : 20. 有效的括号(纸上纯手写)

面试

挨个问笔试的问题。。。

口述了两个方法for循环里操作channel之类的,但是他语言组织的我实在没听懂。。。

  1. 假如有一个高并发的场景,我怎么处理(不能借住其他组件,纯go程序)

然后mq问了两个迷一样的问题。

  1. 他提到了Kafka然后问我用的什么MQ,我说Kafka就是一种mq啊。感觉面试官不是很熟悉Kafka

  2. 接着他问我Kafka里的分组是怎么设置的,我以为他问的是消费者分组。结果他说是topic里的。结果他问的分组是Topic分区。。。

这家就别去了。面试流程很不合理,面试官沟通起来比较费劲,也不是很专业。

杉岩数据

项目拷打

其中问了为什么不用普罗米修斯去监控

  1. 假如你用于通知的Kafka挂了怎么办?有没有对Kafka进行监控?

  2. channel的使用场景?

  3. chaneel关闭之后再读和再关闭会发生什么?

  4. map中的数据delete之后内存会回收吗?

  5. GRPC请求和http请求有什么区别

腾娱

四道基础语法题

c := []int{11, 12, 13}
test(c)
log.Info("c=%v", c)
func test(s []int) {for i := 0; i < 10; i++ {s = append(s, i)}
}
  1. c最后是怎么样的?

func main() {values := []int{1,2,3,4,5,6,7,8,9}for _,v := range values {go func(){println(v)}()}
}
  1. 求输出

func main() {wg := sync.WaitGroup{}for i := 0; i < 5; i++ {go func(wg sync.WaitGroup, i int) {wg.Add(1)fmt.Printf("i:%d\n", i)wg.Done()}(wg, i) }wg.Wait()println("exit")
}
  1. 求输出

func testDefer() (err error) {defer func() {if err != nil {log.Error("defer: %s", err)}}()log.Info("testDefer: %s", "test")return handle()
}func handle()error{return fmt.Errorf("normal:test")
}
  1. 求输出

  1. 改造他让他变得有序
func main() {values := []int{1,2,3,4,5,6,7,8,9}for _,v := range values {go func(){println(v)}()}
}

杉岩二面

项目拷打15分钟

  1. Kafka的消息丢失和消息重复消费。

  2. Kafka和Rabbitmq的区别在哪?(架构、推和拉)

  3. 拉的模式有什么好处(控制消费速度)

  4. 使用分布式锁的过程中应用挂了?

  5. 优雅启停+defer

  6. 使用过期时间+自动续期

  7. 对象存储和文件存储的主要区别是什么?

  8. 分片上传是怎么实现的(文件合并hash一致性校验,引出文件秒传)

  9. 邮箱验证码功能怎么实现的。(redis+邮箱组件)

  10. jwt的格式。加密算法、内容、过期时间

  11. 讲一下defer的原理

  12. 讲一下map的底层结构

  13. map中hash冲突怎么解决(链表、红黑树)

  14. 讲一下go性能调优的案例(pprof,线程日志)

  15. 通过线程日志延伸出,怎么看一个线程在线程日志里是卡在循环还是事件等待?

  16. 线程日志上面会有标记。

  17. 讲一下mysql的事务隔离级别?

  18. 解释一下什么是可重复读?

  19. 事务实现的底层原理?

  20. Redis持久化机制(RDB,AOF)

  21. 为什么持久化的时候是fork子进程处理

  22. 讲一下docker实现容器的基本原理

  23. 用过其他容器运行时吗

  24. K8s有哪些组件?

  25. 你们是用什么control去构建deployment的?(没听懂)

欢迎交流

面经先分享到这里,如果你也有最新Go面经欢迎向我投稿:有偿的哦!

也欢迎你了解一下我们的就业训练营,辅导到你找到工作为止的那种

我们又出成绩啦!大厂Offer集锦!遥遥领先!

这些朋友赢麻了!

这是一个专注程序员升职加薪の知识星球

答疑解惑

需要「简历优化」、「就业辅导」、「职业规划」的朋友可以联系我。

一对一辅导的那种呦!

面试真题共享群

对了,我们准备搞一个金三银四面试真题共享群,互通有无,一起刷题进步,没准能让你能刷到自己意向公司的最新面试题呢。

感兴趣的朋友们可以在社区私信我。

或者加我微信:wangzhongyang1993

关注我的同名公众号:王中阳Go

这篇关于那位拿了多个Offer的大佬分享了最新Go面经的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/849357

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

AI Toolkit + H100 GPU,一小时内微调最新热门文生图模型 FLUX

上个月,FLUX 席卷了互联网,这并非没有原因。他们声称优于 DALLE 3、Ideogram 和 Stable Diffusion 3 等模型,而这一点已被证明是有依据的。随着越来越多的流行图像生成工具(如 Stable Diffusion Web UI Forge 和 ComyUI)开始支持这些模型,FLUX 在 Stable Diffusion 领域的扩展将会持续下去。 自 FLU

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

go基础知识归纳总结

无缓冲的 channel 和有缓冲的 channel 的区别? 在 Go 语言中,channel 是用来在 goroutines 之间传递数据的主要机制。它们有两种类型:无缓冲的 channel 和有缓冲的 channel。 无缓冲的 channel 行为:无缓冲的 channel 是一种同步的通信方式,发送和接收必须同时发生。如果一个 goroutine 试图通过无缓冲 channel

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

【Go】go连接clickhouse使用TCP协议

离开你是傻是对是错 是看破是软弱 这结果是爱是恨或者是什么 如果是种解脱 怎么会还有眷恋在我心窝 那么爱你为什么                      🎵 黄品源/莫文蔚《那么爱你为什么》 package mainimport ("context""fmt""log""time""github.com/ClickHouse/clickhouse-go/v2")func main(

java常用面试题-基础知识分享

什么是Java? Java是一种高级编程语言,旨在提供跨平台的解决方案。它是一种面向对象的语言,具有简单、结构化、可移植、可靠、安全等特点。 Java的主要特点是什么? Java的主要特点包括: 简单性:Java的语法相对简单,易于学习和使用。面向对象:Java是一种完全面向对象的语言,支持封装、继承和多态。跨平台性:Java的程序可以在不同的操作系统上运行,称为"Write once,