1. sync包下有哪些同步原語
- sync.Mutex
- sync.RWMutex
- sync.WaitGroup
- sync.Map
- sync.Pool
- sync.Once
- sync.Cond
2. 怎樣檢測goroutine泄露
- 代碼中定時打印goroutine數量:runtime.NumGoroutine,PProf分析:https://learnku.com/articles/61995
- uber 開源工具goleak
- PProf:但在業務服務的運行場景中,Goroutine 內導致的泄露,大多數處于生產、測試環境,因此更多的是使用 PProf:只要我們調用 http://localhost:6060/debug/pprof/goroutine?debug=1,PProf 會返回所有帶有堆棧跟蹤的 Goroutine 列表。
3. 鎖優化
- 減少持有時間,縮小臨界區
- 優化鎖的粒度,空間換時間
- 讀寫分離,讀寫鎖 & sync.Map
- 使用原子操作,無鎖數據結構
4. 字符串拼接不同方式的區別
- 使用 + 號:"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基準測試
https://cloud.tencent.com/developer/article/2216022
6. grpc和http的區別
gRPC和HTTP都是網絡協議,但是它們之間存在一些顯著的區別。
1)傳輸協議
HTTP使用文本基礎的協議,而gRPC使用的是二進制協議,這意味著gRPC數據包更小,傳輸效率更高。另外,gRPC使用HTTP/2協議,支持多路復用,從而可以更好地處理并發請求。
2)性能差異
gRPC在性能方面優于HTTP。由于使用了二進制格式,因此gRPC傳輸速度更快、更穩定。而且gRPC通過使用連接池,實現客戶端與服務端的長連接機制,使得延遲較低,在高網絡帶寬時表現更好。
3)使用場景
HTTP主要用于Web中瀏覽器和服務器之間的交互,在Web應用程序中非常常見。而gRPC通常用于服務之間的通信,特別是分布式系統中,例如微服務框架等。gRPC具有高性能、低延遲、易擴展等特點,是一個理想的分布式系統通信協議。
4)序列化和反序列化
HTTP在傳輸過程中使用JSON或XML格式來表示數據,需要進行序列化和反序列化。而gRPC則使用了更為高效的protobuf格式,同時也支持JSON等格式。
綜上所述,gRPC和HTTP在不同的場景下各有其優勢,使用時應根據具體情況來進行選擇。如果需要高性能的服務之間通信,則可以選擇gRPC,而在Web瀏覽器與服務器之間傳輸數據時則更適合使用HTTP。
7. CGO 能用到GPM嗎
https://uncledou.site/2022/go-cgo-c-to-go/
附錄:
Go常見面試題
https://learnku.com/articles/62720