阿里京東用Java,唯我騰訊C++ !用C++種是什么體驗(yàn)?
來源 / 微信公眾號(hào):編程指北(ID:cs_dev)
在大學(xué)的時(shí)候,就聽說了阿里、美團(tuán)、京東系是 Java 一派,只有鵝廠獨(dú)樹一幟,以 C/ C++ 為后臺(tái)開發(fā)主力語言。
這是為啥咧?小編也很想知道!

1、為啥選擇 C++
其實(shí)原因呢,我猜也很簡單:
一方面是慣性使然,任何一個(gè)公司都是有技術(shù)棧積累的。
鵝廠在長期使用 C++ 的過程中,開發(fā)了大量基于 C++ 的內(nèi)部組件可以使用, KV存儲(chǔ)、RPC、微服務(wù)框架等等一應(yīng)俱全。
并且都有專門的團(tuán)隊(duì)維護(hù)和經(jīng)過生產(chǎn)環(huán)境考驗(yàn)的,可以 C++ 組件很豐富也很穩(wěn)定。
整個(gè)團(tuán)隊(duì)也是更加熟悉 C++,沒有理由也沒有動(dòng)力去切其它語言,所以就一直在 C++ 的道路上越走越遠(yuǎn)。
另一方面就是兩類公司的基因不太一樣,怎么說?
鵝廠早期是做尋呼機(jī)起步的,后來又做了 QQ,可以看出都是和網(wǎng)絡(luò)、通信相關(guān)的一些軟件,這類基本都是 C/C++ 開發(fā)。
我記得 QQ 自誕生之時(shí)起,用戶便呈拋物線增長,為此 QQ 后臺(tái)服務(wù)器多次瀕臨極限,耗費(fèi)的服務(wù)器巨額增長。
當(dāng)時(shí)的騰訊還不怎么賺錢,用 C/C++ 在性能上更高,相同服務(wù)器數(shù)量能支撐的用戶量應(yīng)該也是大不少的,所以后來應(yīng)該就沿用下來了吧。
后面又進(jìn)入游戲行業(yè),而游戲是對(duì)延時(shí)特別敏感的,所以一般都是用 ?C++。
而阿里早期是做黃頁起步的,據(jù)說當(dāng)時(shí)還是 PHP,后來做電商才切到 Java 的,淘寶、美團(tuán)這類 toB 業(yè)務(wù)的特點(diǎn)就是復(fù)雜,一般選擇 Java 的都比較多。

2、用 C++ 怎么寫后臺(tái)?
在學(xué)校學(xué) C++ 的時(shí)候,我就很好奇 C++ 寫后臺(tái)服務(wù)到底是什么樣的?
因?yàn)?C++ 沒有一個(gè)完善的開源生態(tài)...... 不像 Java、Node、PHP、Flask 這些語言,都有對(duì)應(yīng)的 Web 框架,學(xué)完語言就能用框架寫個(gè)后臺(tái)服務(wù)。
但是 C++ 實(shí)在不知道該怎么寫,寫也只是 解析靜態(tài)的 HTTP 協(xié)議的 WebServer 而已。
去年來騰訊實(shí)習(xí)之后,我才知道這些大廠都是怎么用 C++ 構(gòu)建的后臺(tái)服務(wù)。
由于小北在微信,所以這里就以微信的技術(shù)棧為例了,聊聊在微信用 C++ 做后臺(tái)開發(fā)是一種什么樣的體驗(yàn)?
體驗(yàn)很像 Java!
是的,開發(fā)起來的效率和感覺是無比接近 Java 的,這得益于那些大佬寫的基礎(chǔ)組件很完善。
3、微信后臺(tái)開發(fā)體驗(yàn)
微信后臺(tái)主要使用 C++,后臺(tái)服務(wù)使用 Svrkit 框架搭建,服務(wù)之間通過同步 RPC 進(jìn)行通訊,這個(gè)在百度上也是能搜到一些信息的。

圖源:infoQ
Svrkit 主要是用于開發(fā)后臺(tái)微服務(wù)的框架,基本上開發(fā)三部曲:
(1)制定通信協(xié)議,定義 proto 文件
(2)用命令基于這個(gè) proto 文件生成服務(wù)框架代碼
(3)填充處理業(yè)務(wù)邏輯的函數(shù)(服務(wù))
是不是很像 SpringBoot 這類框架?基本上,業(yè)務(wù)只需要關(guān)注數(shù)據(jù)模型設(shè)計(jì)、數(shù)據(jù)存儲(chǔ)、通信,然后就是實(shí)現(xiàn)具體的業(yè)務(wù)邏輯了。
框架會(huì)自動(dòng)幫你完成打解包、網(wǎng)絡(luò)通信、失敗重試等微服務(wù)框架應(yīng)該做的事。
這是后臺(tái) RPC 服務(wù)的開發(fā),但是我們知道,對(duì)外的接口一般都是用 HTTP 的,所以這里需要用一層接入層做一些協(xié)議轉(zhuǎn)換和參數(shù)、簽名校驗(yàn)等工作。
這一層一般叫做 CGI(估計(jì)也只有鵝廠還喜歡叫 CGI 吧?),CGI 可以用 PHP 開發(fā),也可以用 C++ 寫,這一層的目的就是對(duì)外提供 HTTP(一般是 JSON)訪問接口,然后調(diào)用后臺(tái) RPC 服務(wù)(protobuf)。
當(dāng)然,微信客戶端和后臺(tái) RPC 服務(wù)之間就是走微信的自定義協(xié)議了。

所以,其實(shí)和 Java 在開發(fā)效率上沒什么明顯區(qū)別。
當(dāng)然了,鵝廠也不是所有都是 C++ 開發(fā),幾乎主流的后臺(tái)語言,都會(huì)有不同的團(tuán)隊(duì)在使用,尤其是一些新業(yè)務(wù),沒有歷史負(fù)債的,也會(huì)用 Go、Java 等。
但是微信后臺(tái)幾乎是 C++ 主導(dǎo),所以想來微信做后臺(tái)的同學(xué)可以學(xué)下 C++ ,雖然說校招不會(huì)限制語言,但是 C++ 使用熟練總算是個(gè)加分項(xiàng)吧。
在微信,很多后臺(tái)開發(fā)的組件都是自研的,比如存儲(chǔ)用的KV(MySQL用的比較少)、消息隊(duì)列、RPC 框架等。
這些學(xué)習(xí)上手都是很快的,畢竟技術(shù)思想都是通用的,只是換個(gè)實(shí)現(xiàn)形式、調(diào)用接口而已。
如果想體驗(yàn) C++ 開發(fā)后臺(tái)服務(wù)的同學(xué),可以去看下搜狗開源的 srpc,包括百度 brpc、Google grpc 都是這樣的,用起來很相似。
作為一名編程學(xué)習(xí)者,如果你想更好的提升你的編程能力,好好學(xué)習(xí)C/C++編程知識(shí),以后努力成為高薪軟件開發(fā)工程師的話!

UP在主頁上傳了一些學(xué)習(xí)C/C++編程的視頻教程,有興趣或者正在學(xué)習(xí)的小伙伴一定要去看一看哦!會(huì)對(duì)你有幫助的~
分享(源碼、項(xiàng)目實(shí)戰(zhàn)視頻、項(xiàng)目筆記,基礎(chǔ)入門教程)
歡迎轉(zhuǎn)行和學(xué)習(xí)編程的伙伴,利用更多的資料學(xué)習(xí)成長比自己琢磨更快哦!
編程學(xué)習(xí)書籍:

編程學(xué)習(xí)視頻:
