深信服golang一二面

只记得部分印象深刻的题目

一面(基本全是场景题,一个多小时)
1. 如果一个函数的返回值是error,里面执行了多个defer,并且这些defer里面调用了不同的方法,也会返回error,但是这些error的格式是不一样的(比如有一些方法返回的是官方的errors,有一些是业务定义的错误,比如错误码和错误信息)。怎么样能统一处理这些defer的错误并且返回?(只答了在最后执行的defer进行封装,面试官说可以用泛型实现)
2. channel怎么实现的?(答出来了)里面有锁吗?(有的)那我为什么不直接用锁呢?(尬住了)
3. channel里面有等待队列是吧(是的),那么如果有一个200缓冲区的协程,我一直写,写100w条数据,那等待队列不就很长了吗,占用内存不就很高了吗,为什么channel要这样设计?(难绷)
(答了会有读协程消费,但是面试官说如果读太慢了,或者不给读呢)
4. kmp (只说了next数组),再问如果字符串长度是100w,怎么kmp(绷)
5. 手撕二叉搜索树最近公共祖先,先说思路,然后在纸上写代码
6. option设计模式,手写一个看看(写了一个,但是面试官好像不太认可)
7.  如何控制协程超时退出,手写(答了ctx和timer,但是api有点忘了,没写好)

二面(三十多分钟吧)
1. k8s有什么组件,能不能把架构图画出来(??)
2. docker怎么实现的(namespace,cgroup,unionFS),docker网络架构是怎么样的,画一下,你说的docker0是什么,如果现在有多个容器,那么这些容器网络连接是怎么样的?画一下(??)
3. mysql怎么实现多进程并发写,但是表数据不会乱?(答了mvcc的实现,但是他还是一直问怎么实现的,总共问了三次,第一次说一半打断然后问用什么实现mvcc,答了read view和隐藏列,然后又问一次怎么实现多进程写,不知道是我没说清楚还是他没听……)
4. 假如你是广州市市长,怎么规划城市,处理上下班通勤会塞车这个问题(很奇怪的问题)
5. 手撕链表每k个节点反转一次,后来看我做太久让直接让我做反转链表(但是面试官电脑的牛客ide出bug了,编译不出来,最后就看代码说思路了) #24届软开秋招面试经验大赏#
全部评论
难到爆炸💥
2 回复 分享
发布于 2023-09-26 15:49 广东
不想招人还出来招聘啊这是
1 回复 分享
发布于 2023-10-01 21:37 澳大利亚
mysql怎么实现多进程并发写 —— 是不是要答什么表锁,行锁?
点赞 回复 分享
发布于 2024-06-11 16:07 广东
兄弟你的怎么这么难啊
点赞 回复 分享
发布于 2023-10-14 13:59 河南
谢谢分享,cpp 一知半解现在转golang ,还有两年希望来得及
点赞 回复 分享
发布于 2023-10-05 09:38 广东
这面试牛的
点赞 回复 分享
发布于 2023-10-03 23:59 江西
线下面试?
点赞 回复 分享
发布于 2023-09-27 16:01 江西
哥你这是社招?
点赞 回复 分享
发布于 2023-09-26 18:01 湖南
额,这完全在刁难了,说实话大部分都知道,但是你让我画图这个。。。。
点赞 回复 分享
发布于 2023-09-26 15:51 陕西

相关推荐

04-13 21:39
中南大学 Java
时间:4.10地点:长沙1. 在大学里面学学的那个,大学里面应该是都是自学的吧?2. 我看你当时写的spring java,那你现在面的这个岗位是 golang和 python的技术上多一些,你认为这两个的差异有哪些?>面试官麦不好  我没听清这句话,导致他换成了下面这个质疑性的问题3. 我看你简历上写的都是 spring java,但我们这个岗位是 golang ?4. 先做一个笔试题吧:给你100万条数据(一个表,包括订单 id 和金额),要你从中取出金额最大的前100条,要求时间复杂度尽可能低,并且内存占用要小(不是写 sql,idea 手写,不能用数据库,要求时间复杂度 O(n))5. 你这里的时间、空间复杂度是多少?以这种方式,假设我把100万调成100亿。你这里能运行起来吗?100亿怎么优化呢?看一下运行时间是多长时间。你认为这样是最快的吗?6. 你使用过哪些数据库7. 什么情况下要用 Redis8. 什么情况下你认为是并发比较大?9. 你说数据库性能不行,扛不住,那多大才算扛不住?10. 数据库里面的存储结构类型是什么样子的?11. 为什么是 B+树?12. 怎么保证查询性能,除了加索引,还有什么?13. 有了解过分表吗14. 你平时是怎么学习的15. 现在 AI 的使用情况怎么样16. 反问环节
看得见不:第四题应该是一个容量大小为100的最小堆,先进100个初始化堆,遍历入堆就行了,堆顶就是第100大的,每次和堆顶对比大小,然后调整堆就行了,时间复杂度是n*log100,忽略常数也是n
查看14道真题和解析
点赞 评论 收藏
分享
评论
7
57
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务