• <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>

            戰(zhàn)魂小筑

            討論群:309800774 知乎關注:http://zhihu.com/people/sunicdavy 開源項目:https://github.com/davyxu

               :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              257 隨筆 :: 0 文章 :: 506 評論 :: 0 Trackbacks

            append, map, len不是關鍵字

            他們其實還是類庫功能, 都在buildin包里的, 系統(tǒng)默認給你做了個

            1. import(
            2. . "buildin"
            3. )

            將buildin的包內(nèi)容都映射到全局而已, 其實你也可以用自己的包這么做

            打印的另一種寫法

            想跟腳本一樣調(diào)試打印數(shù)據(jù)么?

            1. println("hello world")

            無需包含任何包, 因為它在buildin包里

            iota不是黑科技

            這是在buildin包里的定義

            1. // iota is a predeclared identifier representing the untyped integer ordinal
            2. // number of the current const specification in a (usually parenthesized)
            3. // const declaration. It is zero-indexed.
            4. const iota = 0 // Untyped int.

            其實go是有泛型概念的

            想想map和數(shù)組的定義 
            只是泛型沒有開放給用戶用而已(只許XX放火,不許XX點燈)

            map是支持多個key的, 而且很方便

            還在為多個key轉(zhuǎn)id的復雜算法而頭疼么?

            1. type myKey struct{
            2. number int
            3. str string
            4. }
            5. func main(){
            6. t := map[ myKey] int {
            7. myKey{ 2, "world"}: 1,
            8. }
            9. fmt.Println(t[myKey{2, "world"}])
            10. }
            11. 輸出: 1

            枚舉是可以轉(zhuǎn)成string的

            默認定義一個枚舉

            1. type MyConst int
            2. const (
            3. MyConst_A MyConst = iota
            4. MyConst_B MyConst = iota
            5. )
            6. func main(){
            7. fmt.Println(MyConst_A)
            8. }

            輸出: 0 
            如果我們想自動化輸出MyConst_A字符串時 
            就需要使用golang的一個工具鏈:golang.org/x/tools/cmd/stringer 
            將其下載, 編譯成可執(zhí)行工具后, 對代碼進行生成 
            生成的代碼會多出一個xx_string.go 
            里面就是枚舉的String()string 函數(shù)

            臨時轉(zhuǎn)換一個接口并調(diào)用的方法

            1. type love struct{
            2. }
            3. func (self*love)foo(){
            4. fmt.Println("love")
            5. }
            6. func main(){
            7. var chaos interface{} = new(love)
            8. chaos.(interface{
            9. foo()
            10. }).foo()
            11. }

            Golang的receiver實際上就是this的變種實現(xiàn)

            1. func( self*MyStruct) foo( p int ){
            2. }

            寫不慣receiver的寫法? 如果這樣改下呢?

            1. func foo( self *MyStruct, p int ){
            2. }

            所以為什么說Golang還是一個C語言嘛

            關于內(nèi)存分配…

            • new 傳入Type類型, 返回*Type類型
            • make 可以在分配數(shù)組時設置預分配大小, new不可以
            • make 能分配數(shù)組,map, 但不能分配結(jié)構(gòu)體和原始類型
            • new 能分配數(shù)組, map, 結(jié)構(gòu)體和原始類型等的所有類型
            • &Type等效于new
            • 切片不需要分配內(nèi)存(make,new), 直接聲明就可以了…

            Golang的反射無法通過一個類型名, 創(chuàng)建其實例

            C#有Assembly概念, 可以在一個Assembly里搜索, 創(chuàng)建實例

            Golang是靜態(tài)類型語言, 如果需要, 只能注冊你需要創(chuàng)建的結(jié)構(gòu)體, 然后將注冊好的map用于創(chuàng)建

            Golang可以替換Python來進行復雜的工具流程處理

            如果你需要跨平臺的工具流程處理, 對Python不熟悉, 可以使用

            1. go run yourcode.go 參數(shù)1 參數(shù)2

            方式來進行工具處理 
            覺得慢, 可以編譯成可執(zhí)行文件

            這樣做的好處: 如果有些類庫本身就是go寫的, Python想使用是很麻煩的, 而Golang來寫則輕而易舉

            例子: 通過go的protobuf庫, 對一些文件進行處理

            Golang可以自動持有方法的接收者實例

            1. type myType struct{
            2. }
            3. func (self*myType) foo( p int){
            4. fmt.Println("hello", p )
            5. }
            6. func main(){
            7. var callback func( int )
            8. ins := new(myType)
            9. callback = ins.foo
            10. callback( 100 )
            11. }

            做過lua的C++代碼綁定的童鞋都清楚: lua只支持外部靜態(tài)或者全局函數(shù)調(diào)用 
            如果要進行C++類成員函數(shù)調(diào)用時, 要自己處理this和成員函數(shù) 
            這種技巧因為早起編譯器的虛表不同平臺實現(xiàn)細節(jié)不統(tǒng)一需要專門處理 
            后面跨平臺虛表統(tǒng)一后, 類成員函數(shù)的調(diào)用寫法也是很惡心復雜的 
            但是Golang的小白式用法, 直接吊打C++, 甚至C#復雜的delegate

            LiteIDE篇: 多開秘籍

            • 找到 菜單->查看->選項->通用->存儲->存儲設置到本地ini文件

            • 關閉LiteIDE

            • 復制LiteIDE整個目錄, 命名文件夾為你的工程名

            • 每個工程所在的LiteIDE的配置將是獨立的, 不會互相干擾

            LiteIDE篇: 測試程序也是可以調(diào)試的

            別以為程序一定要是main開始的才可以調(diào)試

            Golang的測試程序雖然都是一個個Test開頭的函數(shù),但執(zhí)行go test時, 還是有main入口

            在LiteIDE中, 可以在 調(diào)試->開始調(diào)試測試程序里進行測試程序調(diào)試

            LiteIDE篇: 在Windows上可以輸出linux可執(zhí)行文件

            go的工具鏈默認支持交叉編譯 
            在LiteIDE中, 可以通過切換輸出平臺, 輸出不同平臺的可執(zhí)行文件

            posted on 2016-11-02 11:09 戰(zhàn)魂小筑 閱讀(22319) 評論(1)  編輯 收藏 引用 所屬分類: 工具使用及設計Golang

            評論

            # re: Go語言的冷知識 2016-11-22 16:10 思月行云
            很實用,點贊 ^ ^  回復  更多評論
              

            久久99精品久久久久久| 久久精品国产一区二区电影| 精品久久久一二三区| 人妻无码精品久久亚瑟影视| 久久久久久国产精品美女| 国内精品久久久人妻中文字幕| 精品久久香蕉国产线看观看亚洲| 久久精品国产亚洲Aⅴ香蕉| 精品国产乱码久久久久久人妻| 久久久久久久人妻无码中文字幕爆| 99久久精品免费看国产免费| 久久精品人妻中文系列| 99久久精品国产综合一区| 久久亚洲中文字幕精品有坂深雪| 国产精品无码久久四虎| 久久ZYZ资源站无码中文动漫| 久久久WWW成人| 国产精品久久久久国产A级| 思思久久好好热精品国产| 精品久久久久久久久久久久久久久 | 97r久久精品国产99国产精| 亚洲国产精品一区二区三区久久| 久久福利青草精品资源站免费| 久久久久99这里有精品10| 久久国产成人亚洲精品影院| 日本久久久久久中文字幕| 精品久久久久久国产潘金莲| 人妻精品久久无码专区精东影业 | 欧美日韩精品久久久久| 久久国产免费直播| 久久精品无码一区二区三区免费| 久久精品国产一区| 国产成人精品久久一区二区三区av | 国产欧美一区二区久久| 久久久久久亚洲AV无码专区| 亚洲av伊人久久综合密臀性色| 久久久久亚洲国产| 少妇久久久久久久久久| 99久久超碰中文字幕伊人| 国产精品久久久久9999高清| 久久精品国产只有精品2020|