亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

【第四十二期】米哈游后臺golang開發面經

標簽:
Go
  • 介绍一下自己
  • 一开始问项目(我的项目跟网络相关)中的拥塞控制、流量控制;
  • 简单介绍了一下协议做的事情。有什么拥塞控制协议:Reno和BBR
  • 介绍一下Reno协议的工作方式;
  • UDP 和 TCP 的区别,都适合什么场景:在游戏中使用KCP协议比较多。
  • 引申了一下HTTP 的状态码:1~5开头各是什么作用
  • 用HTTP可以实现主动推送的功能吗,为什么不使用HTTP而是使用 websocket(项目中使用了websocket )
  • HTTP1.1 中也实现了长连接,但是这个长连接中服务器还是被动的,而且HTTP都是基于文本的,虽然底层TCP没有断开,发送消息还是包含太多不必要的头部信息(带宽消耗大),所以在某些场景还是 websocket 好用。
  • HTTP2中对上述的两个缺点做了些优化,比如压缩头部,再比如可以支持服务器主动推送(相当于预加载),但是客户端还是主导地位,可以发送RST_STREAM 来显式的停止这种推送。
  • TCP 的各种标志位(发现我不熟这些标志位),又开始问TCP的三次握手
  • TCP 有多个控制位,SYNC是开启连接,FIN是结束连接(单向断开,优雅断开),ACK是指回复包,RST是异常断开(双向都直接不能处理了),PSH是类似于FLUSH,告诉对方可以将缓冲区的数据直接上报道应用层了(还是有序的),URG(把这一个包上报应用层,数据包可能是无序的)
  • 问 golang 的协程:Goroutine 阻塞的话,是不是对应的M也会阻塞
  • 问一道思考题:如何并发100个任务,但是同一时间最多运行的10个任务(waitgroup + channel)
點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
全棧工程師
手記
粉絲
1
獲贊與收藏
4

關注作者,訂閱最新文章

閱讀免費教程

  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消