Go面試題總結(jié)

1. sync包下有哪些同步原語(yǔ)
  • sync.Mutex
  • sync.RWMutex
  • sync.WaitGroup
  • sync.Map
  • sync.Pool
  • sync.Once
  • sync.Cond
2. 怎樣檢測(cè)goroutine泄露
  • 代碼中定時(shí)打印goroutine數(shù)量:runtime.NumGoroutine,PProf分析:https://learnku.com/articles/61995
  • uber 開(kāi)源工具goleak
  • PProf:但在業(yè)務(wù)服務(wù)的運(yùn)行場(chǎng)景中,Goroutine 內(nèi)導(dǎo)致的泄露,大多數(shù)處于生產(chǎn)、測(cè)試環(huán)境,因此更多的是使用 PProf:只要我們調(diào)用 http://localhost:6060/debug/pprof/goroutine?debug=1,PProf 會(huì)返回所有帶有堆棧跟蹤的 Goroutine 列表。
3. 鎖優(yōu)化
  • 減少持有時(shí)間,縮小臨界區(qū)
  • 優(yōu)化鎖的粒度,空間換時(shí)間
  • 讀寫(xiě)分離,讀寫(xiě)鎖 & sync.Map
  • 使用原子操作,無(wú)鎖數(shù)據(jù)結(jié)構(gòu)
4. 字符串拼接不同方式的區(qū)別
  • 使用 + 號(hào):"abc" + "def"
  • 使用 fmt.Sprintf
  • 使用 strings.Join:適用于切片
  • strings.Builder:性能好

https://geektutu.com/post/hpg-string-concat.html
https://blog.csdn.net/xz_studying/article/details/106602307

5. benchmark基準(zhǔn)測(cè)試

https://cloud.tencent.com/developer/article/2216022

6. grpc和http的區(qū)別

gRPC和HTTP都是網(wǎng)絡(luò)協(xié)議,但是它們之間存在一些顯著的區(qū)別。

1)傳輸協(xié)議
HTTP使用文本基礎(chǔ)的協(xié)議,而gRPC使用的是二進(jìn)制協(xié)議,這意味著gRPC數(shù)據(jù)包更小,傳輸效率更高。另外,gRPC使用HTTP/2協(xié)議,支持多路復(fù)用,從而可以更好地處理并發(fā)請(qǐng)求。

2)性能差異
gRPC在性能方面優(yōu)于HTTP。由于使用了二進(jìn)制格式,因此gRPC傳輸速度更快、更穩(wěn)定。而且gRPC通過(guò)使用連接池,實(shí)現(xiàn)客戶(hù)端與服務(wù)端的長(zhǎng)連接機(jī)制,使得延遲較低,在高網(wǎng)絡(luò)帶寬時(shí)表現(xiàn)更好。

3)使用場(chǎng)景
HTTP主要用于Web中瀏覽器和服務(wù)器之間的交互,在Web應(yīng)用程序中非常常見(jiàn)。而gRPC通常用于服務(wù)之間的通信,特別是分布式系統(tǒng)中,例如微服務(wù)框架等。gRPC具有高性能、低延遲、易擴(kuò)展等特點(diǎn),是一個(gè)理想的分布式系統(tǒng)通信協(xié)議。

4)序列化和反序列化
HTTP在傳輸過(guò)程中使用JSON或XML格式來(lái)表示數(shù)據(jù),需要進(jìn)行序列化和反序列化。而gRPC則使用了更為高效的protobuf格式,同時(shí)也支持JSON等格式。

綜上所述,gRPC和HTTP在不同的場(chǎng)景下各有其優(yōu)勢(shì),使用時(shí)應(yīng)根據(jù)具體情況來(lái)進(jìn)行選擇。如果需要高性能的服務(wù)之間通信,則可以選擇gRPC,而在Web瀏覽器與服務(wù)器之間傳輸數(shù)據(jù)時(shí)則更適合使用HTTP。

7. CGO 能用到GPM嗎

https://uncledou.site/2022/go-cgo-c-to-go/

附錄:
Go常見(jiàn)面試題
https://learnku.com/articles/62720

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容