一:前言
剛看了一篇軟文,說什么“才華是改變人生最有效的途徑”,反正呢,大體就是科技進步,要想一直在車上,就得不斷的學習,剛好最近也准備學習Golang,最近火的不能在火了吧,剛好也有些Python基礎,所以就想在學習Golang的同時,對比着Python,查漏補缺下Python的知識,我終相信語言是相同的,只是個別語法不一樣,翻看以前寫的Python筆記,現在回過頭看看,挺潦草的哈,所以也准備借這個機會,把Python的筆記該重構的重構,該補充的補充,同時記錄下Golang的學習歷程。
二:特點
1.Python
①解釋型語言
程序不需要在運行前編譯,在運行程序的時候才翻譯,專門的解釋器負責在每個語句執行的時候解釋程序代碼。這樣解釋型語言每執行一次就要翻譯一次,效率比較低。
②動態數據類型
支持重載運算符,也支持泛型設計。(運算符重載,就是對已有的運算符重新進行定義,賦予其另一種功能,以適應不同的數據類型。泛型設計就是定義的時候不需要指定類型,在客戶端使用的時候再去指定類型)
③完全面向對象的語言
函數,模塊,數字,字符串都是對象,在Python中,一切接對象
完全支持繼承,重載,多重繼承
④擁有強大的標准庫
Python語言的核心只包含數字,字符串,列表,元祖,字典,集合,文件等常見類型和函數,而由Python標准庫提供了系統管理,網絡通信,文本處理,數據庫接口,圖形系統,XML處理等額外的功能。
⑤社區提供了大量第三方庫
靜態類型語言,但是有動態語言的感覺。(靜態類型的語言就是可以在編譯的時候檢查出來隱藏的大多數問題,動態語言的感覺就是有很多的包可以使用,寫起來的效率很高)
可直接編譯成機器碼,不依賴其他庫,glibc的版本有一定要求,部署就是扔一個文件上去就完成了。
語言層面支持並發,這個就是Go最大的特色,天生的支持並發。Go就是基因里面支持的並發,可以充分的利用多核,很容易的使用並發。
②垃圾回收機制
內置runtime,支持垃圾回收,這屬於動態語言的特性之一吧,雖然目前來說GC(內存垃圾回收機制)不算完美,但是足以應付我們所能遇到的大多數情況,特別是Go1.1之后的GC。
豐富的標准庫
Go目前已經內置了大量的庫,特別是網絡庫非常強大。
處理日志、數據打包、虛擬機處理、文件系統等。
②分布式系統,數據庫代理器等
③網絡編程
這一塊目前應用最廣,包括Web應用、API應用、下載應用。
④內存數據庫
如google開發的groupcache,couchbase的部分組建。
⑥雲平台