go语言137道面试题整理汇总( 二 )


36、用过什么消息中间件之类吗?没有
37、有什么问题吗?评价?后面还有面试,后面再问吧
38、生产者消费者模式,手写代码(Go直接使用channel实现很简单,还想着面试官会不会不让用channel实现,不用channel的可以使用数组加条件变量),channel缓冲长度怎么决定,怎么控制上游生产速度过快,这里没说出解决方案,只是简单说了channel长度可以与上下游的速度比例成线性关系,面试官说这是一种解决方案
39、手写循环队列
40、写的循环队列是不是线程安全,不是,怎么保证线程安全,加锁,效率有点低啊,然后面试官就提醒Go推崇原子操作和channel
41、写完代码面试官说后面问的问题回答就可以,不知道的话没关系
42、Linux会不会,只会几个命令,面试官就说一共也就一百多个命令
43、TimeWait和CloseWait原因
44、线段树了解吗?不了解,字典树?了解
45、看过啥源码,nsq(Go的消息中间件),简单问了我里面的waitgroup包证明我看过
46、sync.Pool用过吗,为什么使用,对象池,避免频繁分配对象(GC有关),那里面的对象是固定的吗?不清楚,没看过这个的源码
47、有什么问题吗?评价?基础不错,Linux尚缺,Go的理解不够深入,高级数据结构不了解,优点是看源码
48、后面面试官讲了他们做的东西,主要是广告部分,说日均数据量至少百万以上,多达上亿,高并发使用Go支撑,有微服务,服务治理,说我需要学的东西挺多的
49、证明二叉树的叶子节点跟度数为2的节点的关系
50、唯一索引和主键索引
51、智能指针
52、字符串解析为数字(考虑浮点型)
53、单点登录,tcp粘包
54、手写洗牌
55、处理粘包断包实现,面试官以为是negle算法有关,解释了下negle跟糊涂窗口综合征有关,然后面试官觉得其他项目是crud就没问了
56、goroutine调度用了什么系统调用,这个不会,面试官想从go问到操作系统,然后以为***作系统基础不好,就问了操作系统问题
57、进程虚拟空间分布,全局变量放哪里?答上来了,操作系统就不问了
58、有没有网络编程,有,怎么看连接状态?netstat,有哪些?ESTABLISHED,LISTEN等等,有异常情况吗?TIME_WAIT很多,为什么?大量短链接
59、几种基本排序算法说一下,问了堆的时间复杂度,稳定性,为什么不稳定
60、 topk问题,海量数据topk(回答成切分多次加载内存,然后用维持k长度的有序链表,然后被说时间复杂度不好,提示说还是用堆,然后哦哦哦对)最长连续字串和,这里我说的解决方案没用dp(对dp不熟),面试官一直引导我dp,还是不会
61、什么是主键62、联合索引和唯一索引
62、越多的索引越好吗?
63、建立索引要注意什么?
64、进程和线程区别?
65、死锁?
66、tcp三次握手
67、http,https
68、状态码401,301,302,201
69、项目我说只有一台机子,所以用的单机部署,面试官说单机也可以部署多个,有什么方法吗?我说Docker,问docker有哪些网络,不熟,dockerfile关键字,只答几个 。顺便扯了下Nginx转发 。
70、数据库隔离级别,提交读会造成什么
71、go调度
72、 goroutine泄漏有没有处理,设置timeout,select加定时器
73、mysql高可用的方案
74、进程线程区别
75、排序算法以及时间复杂度
76、怎么学习go
77、go的线程,给他讲了跟goroutine调度
78、io模型,同步阻塞,同步非阻塞,异步
79、cookie和session
实习项目优缺点同学的评价兴趣爱好有什么offer80、接口kps测试
81、redis排行榜数据结构(跳跃表),查询时间复杂度
82、redis分布式,如何减少同步延迟
83、mysql能实现redis的功能吗
84、平时怎么学习?
85、看什么书?
86、兴趣爱好
87、看过google四篇分布式论文吗,没看过
89、cap理论,举例
90、LRU算法,LFU
91、讲讲怎么理解网络编程
92、go使用踩过什么坑(for range,数据库连接defer close)
93、go优缺点
95、go的值传递和引用
96、慢查询
97、为什么使用pg
98、redis的数据类型
99、所有左叶子节点的和
100、m个n大小的有序数组求并集,一开始是2路归并,求时间复杂度,后来在面试官提醒直接m路归并,求时间复杂度


推荐阅读