很多編程語言對比的文章,總喜歡比較各種編程語言的性能、語法、IO模型。本文將從心智負擔這個角度去比較下不同的編程語言和技術。
內存越界
如:C語言、C++(C with class)
C/C++可以直接操作內存,但編程必須要面對內存越界問題。發生內存越界后,程序會直接core dump,開發者需要使用gdb工具分析內存錯誤的原因,如果內存越界是偶發的,比如由於數據同步問題造成,數億次中會出現一次,解決起來非常困難,甚至需要頂級專家才能找到問題原因。
心智負擔:10
現代C++提供了STL庫包含大量容器,另外C++支持引用語法,不再需要直接操作指針,降低了內存錯誤讀寫的風險。使用現代C++的編程風格可以避免此問題。但由於C++沒有完全從語法層面移除指針,不夠徹底。
宏
C/C++程序中經常使用預定義宏實現一些邏輯,導致可讀性變差。有些情況下會嵌套多次宏的使用,展開后變得極其難讀。
心智負擔:6
因此在C/C++中建議使用enum或static inline函數代替宏。
內存管理
如:C語言、C++
C/C++語言,需要手工管理內存,malloc/new申請的內存要與free/delete成對使用。申請的內存忘記釋放,就會出現內存泄漏。
心智負擔:8
Java/PHP/Go等有GC的編程語言,不需要手工管理內存,不會因為代碼錯誤引起內存泄漏。
心智負擔:0
數值類型
C/C++/GO等編程語言,提供了有符號、無符號整型和浮點型,8/16/32/64不同尺寸的整型。編程時需要額外處理,避免數值溢出。
心智負擔:6
PHP/Java等編程語言,默認整數為有符號int64,降低了心智負擔。一般業務項目中很難有超過2^63的數字,不會遇到問題。但如果是做科學計算,int64就難以滿足需求了。在PHP中超過2^63底層會轉為浮點型,計算將丟失精度。
心智負擔:1
而Python整數是不限長度的,可以做任意位數的數值計算。
心智負擔:0
類型約束
Java是靜態強類型編程語言,因此在編程中存在類型約束,某些情況下可能不是特別方便。如JSON序列化。不同類型的變量互相操作時可能需要進行顯式類型轉換。
心智負擔:2
PHP/JS是動態弱類型編程語言,底層自動進行隱式類型轉換。編程更方便。
心智負擔:0。
項目維護
在大型項目,或對已有系統進行代碼重構,以及項目代碼更換開發者時,弱類型帶來可維護性、可讀性的難題,與Java/Go/C++這樣的靜態強類型編程語言在編譯期就可以發現問題。而動態、弱類型語言可能會因為重構或其他維護操作產生運行時錯誤,增加了心智負擔。
心智負擔:5
多線程編程
Java/C++/Go提供了多線程並行編程、無鎖編程,在編程中會存在數據同步問題。因此需要對臨界資源進行加鎖。而錯誤的鎖操作又會帶來,死鎖和熱點爭搶問題。需要開發者具備極高的素質,否則難以做到正確無誤並性能良好,這可能需要耗費大量心智。
心智負擔:10
內存泄漏
除PHP(php-fpm)之外的其他編程語言和技術(包括PHP + Swoole),在服務器端程序中均為長生命周期。對全局/靜態變量操作可能會導致內存或資源句柄泄漏。編程時需要注意。
心智負擔:3
而PHP(php-fpm)是短生命周期的,在請求結束后會立即釋放所有內存和句柄,無需擔心泄漏。
心智負擔:0
IO 超時
同步阻塞IO模型的編程語言和技術,在遇到某個慢IO會導致整個進程或線程掛起。極端情況下會出現所有進程/線程掛起,引起線上服務不可用。開發者需要格外注意設置IO操作的超時時間,避免慢請求帶來進程/線程阻塞。
心智負擔:2
而且異步IO的Go/Node.js/Swoole等無需擔心此問題。
心智負擔:0
匯總

看到這里是不是又有很多感悟了呢~
如果你很想學會編程,那么小編推薦我的C語言/C++編程學習基地【點擊進入】!
都是學編程小伙伴們,帶你入個門還是簡簡單單啦,一起學習,一起加油~
還有許多學習資料和視頻,相信你會喜歡的!
涉及:游戲開發、常用軟件開發、編程基礎知識、課程設計、黑客等等......
