• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2017年1月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 219196
            • 排名 - 117

            最新評論

            閱讀排行榜

            http://www.zhihu.com/question/21409296
            http://blog.csdn.net/johnhomsea/article/details/18944647

            1、Go有什么優勢

            • 可直接編譯成機器碼,不依賴其他庫,glibc的版本有一定要求,部署就是扔一個文件上去就完成了。
            • 靜態類型語言,但是有動態語言的感覺,靜態類型的語言就是可以在編譯的時候檢查出來隱藏的大多數問題,動態語言的感覺就是有很多的包可以使用,寫起來的效率很高。
            • 語言層面支持并發,這個就是Go最大的特色,天生的支持并發,我曾經說過一句話,天生的基因和整容是有區別的,大家一樣美麗,但是你喜歡整容的還是天生基因的美麗呢?Go就是基因里面支持的并發,可以充分的利用多核,很容易的使用并發。
            • 內置runtime,支持垃圾回收,這屬于動態語言的特性之一吧,雖然目前來說GC不算完美,但是足以應付我們所能遇到的大多數情況,特別是Go1.1之后的GC。
            • 簡單易學,Go語言的作者都有C的基因,那么Go自然而然就有了C的基因,那么Go關鍵字是25個,但是表達能力很強大,幾乎支持大多數你在其他語言見過的特性:繼承、重載、對象等。
            • 豐富的標準庫,Go目前已經內置了大量的庫,特別是網絡庫非常強大,我最愛的也是這部分。
            • 內置強大的工具,Go語言里面內置了很多工具鏈,最好的應該是gofmt工具,自動化格式化代碼,能夠讓團隊review變得如此的簡單,代碼格式一模一樣,想不一樣都很困難。
            • 跨平臺編譯,如果你寫的Go代碼不包含cgo,那么就可以做到window系統編譯linux的應用,如何做到的呢?Go引用了plan9的代碼,這就是不依賴系統的信息。
            • 內嵌C支持,前面說了作者是C的作者,所以Go里面也可以直接包含c代碼,利用現有的豐富的C庫。
            2、Go適合用來做什么
            • 服務器編程,以前你如果使用C或者C++做的那些事情,用Go來做很合適,例如處理日志、數據打包、虛擬機處理、文件系統等。
            • 分布式系統,數據庫代理器等
            • 網絡編程,這一塊目前應用最廣,包括Web應用、API應用、下載應用、
            • 內存數據庫,前一段時間google開發的groupcache,couchbase的部分組建
            • 云平臺,目前國外很多云平臺在采用Go開發,CloudFoundy的部分組建,前VMare的技術總監自己出來搞的apcera云平臺。
            3、Go成功的項目
            nsq:bitly開源的消息隊列系統,性能非常高,目前他們每天處理數十億條的消息
            docker:基于lxc的一個虛擬打包工具,能夠實現PAAS平臺的組建。
            packer:用來生成不同平臺的鏡像文件,例如VM、vbox、AWS等,作者是vagrant的作者
            skynet:分布式調度框架
            Doozer:分布式同步工具,類似ZooKeeper
            Heka:mazila開源的日志處理系統
            cbfs:couchbase開源的分布式文件系統
            tsuru:開源的PAAS平臺,和SAE實現的功能一模一樣
            groupcache:memcahe作者寫的用于Google下載系統的緩存系統
            god:類似redis的緩存系統,但是支持分布式和擴展性
            gor:網絡流量抓包和重放工具
            以下是一些公司,只是一小部分:
            下面列出來了一些使用的用戶
            GoUsers - go-wiki - A list of organizations that use Go.
            4、Go還存在的缺點
            以下缺點是我自己在項目開發中遇到的一些問題:
            • Go的import包不支持版本,有時候升級容易導致項目不可運行,所以需要自己控制相應的版本信息
            • Go的goroutine一旦啟動之后,不同的goroutine之間切換不是受程序控制,runtime調度的時候,需要嚴謹的邏輯,不然goroutine休眠,過一段時間邏輯結束了,突然冒出來又執行了,會導致邏輯出錯等情況。
            • GC延遲有點大,我開發的日志系統傷過一次,同時并發很大的情況下,處理很大的日志,GC沒有那么快,內存回收不給力,后來經過profile程序改進之后得到了改善。
            • pkg下面的圖片處理庫很多bug,還是使用成熟產品好,調用這些成熟庫imagemagick的接口比較靠譜


            最后還是建議大家學習Go,這門語言真的值得大家好好學習,因為它可以做從底層到前端的任何工作。
            posted on 2016-09-05 11:56 思月行云 閱讀(609) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            色综合久久天天综合| 久久狠狠一本精品综合网| 狠狠色狠狠色综合久久| 久久AV高潮AV无码AV| 久久91亚洲人成电影网站| 久久亚洲天堂| 91精品国产91久久综合| 一本久久精品一区二区| 国内精品久久久人妻中文字幕| 久久久久亚洲AV无码永不| 久久久精品久久久久久| 久久香综合精品久久伊人| 久久国产精品偷99| 久久精品一本到99热免费| 久久免费视频一区| 精品国产一区二区三区久久久狼| 久久久久99精品成人片牛牛影视| 久久综合香蕉国产蜜臀AV| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久精品国产色蜜蜜麻豆| 国产精品久久久久久影院| 久久亚洲精品无码VA大香大香| 久久九九全国免费| aaa级精品久久久国产片| 久久精品免费全国观看国产| 亚洲国产成人久久精品影视| 久久亚洲欧美国产精品| 伊人久久大香线蕉av不卡| 久久中文精品无码中文字幕| 亚洲国产精品婷婷久久| 久久综合噜噜激激的五月天| 亚洲欧洲精品成人久久曰影片| 久久久久国产| 久久无码AV中文出轨人妻| 久久精品国产亚洲一区二区三区| 欧美激情精品久久久久| 久久精品视频网| 9999国产精品欧美久久久久久| 狠狠色婷婷久久一区二区三区| 久久久www免费人成精品| 久久人人爽人人爽人人片AV东京热|