• <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年5月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910


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

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 215436
            • 排名 - 118

            最新評論

            閱讀排行榜

            http://studygolang.com/articles/2228

            一、一般操作

              1,聲明變量,go自動初始化為nil,長度:0,地址:0,nil

            復(fù)制代碼
            func main(){
                var ss []string;
                fmt.Printf("length:%v \taddr:%p \tisnil:%v",len(ss),ss, ss==nil)    
            }
            
            ---
            Running...
            
            length:0     addr:0x0     isnil:true
            Success: process exited with code 0.
            復(fù)制代碼

              2,切片的追加,刪除,插入操作

            復(fù)制代碼
            func main(){
                var ss []string;
                fmt.Printf("[ local print ]\t:\t length:%v\taddr:%p\tisnil:%v\n",len(ss),ss, ss==nil)    
                print("func print",ss)
                //切片尾部追加元素append elemnt
                for i:=0;i<10;i++{
                    ss=append(ss,fmt.Sprintf("s%d",i));
                }
                fmt.Printf("[ local print ]\t:\tlength:%v\taddr:%p\tisnil:%v\n",len(ss),ss, ss==nil)    
                print("after append",ss)
                //刪除切片元素remove element at index
                index:=5;
                ss=append(ss[:index],ss[index+1:]...)
                print("after delete",ss)
                //在切片中間插入元素insert element at index;
            //注意:保存后部剩余元素,必須新建一個(gè)臨時(shí)切片
                rear:=append([]string{},ss[index:]...)
                ss=append(ss[0:index],"inserted")
                ss=append(ss,rear...)
                print("after insert",ss)
            }
            func print(msg string,ss []string){
                fmt.Printf("[ %20s ]\t:\tlength:%v\taddr:%p\tisnil:%v\tcontent:%v",msg,len(ss),ss, ss==nil,ss)    
                fmt.Println()
            }
            ------
            Running...

            [ local print ]    :     length:0    addr:0x0    isnil:true
            [           func print ]    :    length:0    addr:0x0    isnil:true    content:[]
            [ local print ]    :    length:10    addr:0xc208056000    isnil:false
            [         after append ]    :    length:10    addr:0xc208056000    isnil:false    content:[s0 s1 s2 s3 s4 s5 s6 s7 s8 s9]
            [         after delete ]    :    length:9    addr:0xc208056000    isnil:false    content:[s0 s1 s2 s3 s4 s6 s7 s8 s9]
            [         after insert ]    :    length:10    addr:0xc208056000    isnil:false    content:[s0 s1 s2 s3 s4 inserted s6 s7 s8 s9]

            Success: process exited with code 0.
            復(fù)制代碼

               3,copy的使用。

            在使用copy復(fù)制切片之前,要保證目標(biāo)切片有足夠的大小,注意是大小,而不是容量,還是看例子:

            復(fù)制代碼
            func main() {
                var sa = make ([]string,0);
                for i:=0;i<10;i++{
                    sa=append(sa,fmt.Sprintf("%v",i))
                    
                }
                var da =make([]string,0,10);
                var cc=0;
                cc= copy(da,sa);
                fmt.Printf("copy to da(len=%d)\t%v\n",len(da),da)
                da = make([]string,5)
                cc=copy(da,sa);
                fmt.Printf("copy to da(len=%d)\tcopied=%d\t%v\n",len(da),cc,da)
                 da = make([]string,10)
                cc =copy(da,sa);
                fmt.Printf("copy to da(len=%d)\tcopied=%d\t%v\n",len(da),cc,da)
                
            }
            
            ---
            Running...
            
            copy to da(len=0)    []
            copy to da(len=5)    copied=5    [0 1 2 3 4]
            copy to da(len=10)    copied=10    [0 1 2 3 4 5 6 7 8 9]

            復(fù)制代碼

              從上面運(yùn)行結(jié)果,明顯看出,目標(biāo)切片大小0,容量10,copy不能復(fù)制。目標(biāo)切片大小小于源切片大小,copy就按照目標(biāo)切片大小復(fù)制,不會報(bào)錯。

            二、初始大小和容量

              當(dāng)我們使用make初始化切片的時(shí)候,必須給出size。go語言的書上一般都會告訴我們,當(dāng)切片有足夠大小的時(shí)候,append操作是非常快的。但是當(dāng)給出初始大小后,我們得到的實(shí)際上是一個(gè)含有這個(gè)size數(shù)量切片類型的空元素,看例子:

            復(fù)制代碼
            func main(){
                var ss=make([]string,10);
                ss=append(ss,"last");
                print("after append",ss)
                
            }
            ---
            Running...

            [         after append ]    :    length:11    addr:0xc20804c000    isnil:false    content:[          last]
            復(fù)制代碼

              實(shí)際上,此時(shí)我們應(yīng)該先用下標(biāo)為切片元素負(fù)值。但是如果我們既想有好的效率,有想繼續(xù)使用append函數(shù)而不想?yún)^(qū)分是否有空的元素,此時(shí)就要請出make的第三個(gè)參數(shù),容量,也就是我們通過傳遞給make,0的大小和足夠大的容量數(shù)值就行了。

            復(fù)制代碼
            func main(){
                var ss=make([]string,0,10);
                ss=append(ss,"last");
                print("after append",ss)
                
            }
            
            ---
            Running...
            
            [         after append ]    :    length:1    addr:0xc20804a000    isnil:false    content:[last]
            復(fù)制代碼

             

            三、切片的指針。

              1,當(dāng)我們用append追加元素到切片時(shí),如果容量不夠,go就會創(chuàng)建一個(gè)新的切片變量,看下面程序的執(zhí)行結(jié)果:

            復(fù)制代碼
            func main() {
                var sa []string
            fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
                for i:=0;i<10;i++{
                    sa=append(sa,fmt.Sprintf("%v",i))
                    fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
                }
                fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
            
            }

            ---
            Running ...
            addr:0x0 len:0 content:[] addr:0x1030e0c8 len:1 content:[0] addr:0x10328120 len:2 content:[0 1] addr:0x10322180 len:3 content:[0 1 2] addr:0x10322180 len:4 content:[0 1 2 3] addr:0x10342080 len:5 content:[0 1 2 3 4] addr:0x10342080 len:6 content:[0 1 2 3 4 5] addr:0x10342080 len:7 content:[0 1 2 3 4 5 6] addr:0x10342080 len:8 content:[0 1 2 3 4 5 6 7] addr:0x10324a00 len:9 content:[0 1 2 3 4 5 6 7 8] addr:0x10324a00 len:10 content:[0 1 2 3 4 5 6 7 8 9] addr:0x10324a00 len:10 content:[0 1 2 3 4 5 6 7 8 9]

            //很明顯,切片的地址經(jīng)過了數(shù)次改變。
            復(fù)制代碼

               2,如果,在make初始化切片的時(shí)候給出了足夠的容量,append操作不會創(chuàng)建新的切片:

            復(fù)制代碼
            func main() {
                var sa = make ([]string,0,10);
            fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
                for i:=0;i<10;i++{
                    sa=append(sa,fmt.Sprintf("%v",i))
                    fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
                }
                fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
            
            }
            復(fù)制代碼
            復(fù)制代碼
            addr:0x10304140         len:0 content:[]
            addr:0x10304140         len:1 content:[0]
            addr:0x10304140         len:2 content:[0 1]
            addr:0x10304140         len:3 content:[0 1 2]
            addr:0x10304140         len:4 content:[0 1 2 3]
            addr:0x10304140         len:5 content:[0 1 2 3 4]
            addr:0x10304140         len:6 content:[0 1 2 3 4 5]
            addr:0x10304140         len:7 content:[0 1 2 3 4 5 6]
            addr:0x10304140         len:8 content:[0 1 2 3 4 5 6 7]
            addr:0x10304140         len:9 content:[0 1 2 3 4 5 6 7 8]
            addr:0x10304140         len:10 content:[0 1 2 3 4 5 6 7 8 9]
            addr:0x10304140         len:10 content:[0 1 2 3 4 5 6 7 8 9]

            //可見,切片的地址一直保持不變
            復(fù)制代碼


               3, 如果不能準(zhǔn)確預(yù)估切片的大小,又不想改變變量(如:為了共享數(shù)據(jù)的改變),這時(shí)候就要請出指針來幫忙了,下面程序中,sa就是osa這個(gè)切片的指針,我們共享切片數(shù)據(jù)和操作切片的時(shí)候都使用這個(gè)切片地址就ok了,其本質(zhì)上是:append操作亦然會在需要的時(shí)候構(gòu)造新的切片,不過是將地址都保存到了sa中,因此我們通過該指針始終可以訪問到真正的數(shù)據(jù)。

            復(fù)制代碼
            func main() {
                var osa = make ([]string,0);
                sa:=&osa;
                for i:=0;i<10;i++{
                    *sa=append(*sa,fmt.Sprintf("%v",i))
                    fmt.Printf("addr of osa:%p,\taddr:%p \t content:%v\n",osa,sa,sa);
                }
                fmt.Printf("addr of osa:%p,\taddr:%p \t content:%v\n",osa,sa,sa);
               
            }

            ---
            Running...

            addr of osa:0xc20800a220,    addr:0xc20801e020      content:&[0]
            addr of osa:0xc20801e0a0,    addr:0xc20801e020      content:&[0 1]
            addr of osa:0xc20803e0c0,    addr:0xc20801e020      content:&[0 1 2]
            addr of osa:0xc20803e0c0,    addr:0xc20801e020      content:&[0 1 2 3]
            addr of osa:0xc208050080,    addr:0xc20801e020      content:&[0 1 2 3 4]
            addr of osa:0xc208050080,    addr:0xc20801e020      content:&[0 1 2 3 4 5]
            addr of osa:0xc208050080,    addr:0xc20801e020      content:&[0 1 2 3 4 5 6]
            addr of osa:0xc208050080,    addr:0xc20801e020      content:&[0 1 2 3 4 5 6 7]
            addr of osa:0xc208052000,    addr:0xc20801e020      content:&[0 1 2 3 4 5 6 7 8]
            addr of osa:0xc208052000,    addr:0xc20801e020      content:&[0 1 2 3 4 5 6 7 8 9]
            addr of osa:0xc208052000,    addr:0xc20801e020      content:&[0 1 2 3 4 5 6 7 8 9]
            復(fù)制代碼


            通用Contains方法


            package main

            import (
                "errors"
                "fmt"
                "reflect"
            )

            // 判斷obj是否在target中,target支持的類型arrary,slice,map
            func Contain(obj interface{}, target interface{}) (bool, error) {
                targetValue := reflect.ValueOf(target)
                switch reflect.TypeOf(target).Kind() {
                case reflect.Slice, reflect.Array:
                    for i := 0; i < targetValue.Len(); i++ {
                        if targetValue.Index(i).Interface() == obj {
                            return true, nil
                        }
                    }
                case reflect.Map:
                    if targetValue.MapIndex(reflect.ValueOf(obj)).IsValid() {
                        return true, nil
                    }
                }

                return false, errors.New("not in array")
            }

            func main() {
                testMap()

                testArray()
                testSlice()
            }

            func testArray() {
                a := 1
                b := [3]int{1, 2, 3}

                fmt.Println(Contain(a, b))

                c := "a"
                d := [4]string{"b", "c", "d", "a"}
                fmt.Println(Contain(c, d))

                e := 1.1
                f := [4]float64{1.2, 1.3, 1.1, 1.4}
                fmt.Println(Contain(e, f))

                g := 1
                h := [4]interface{}{2, 4, 6, 1}
                fmt.Println(Contain(g, h))

                i := [4]int64{}
                fmt.Println(Contain(a, i))
            }

            func testSlice() {
                a := 1
                b := []int{1, 2, 3}

                fmt.Println(Contain(a, b))

                c := "a"
                d := []string{"b", "c", "d", "a"}
                fmt.Println(Contain(c, d))

                e := 1.1
                f := []float64{1.2, 1.3, 1.1, 1.4}
                fmt.Println(Contain(e, f))

                g := 1
                h := []interface{}{2, 4, 6, 1}
                fmt.Println(Contain(g, h))

                i := []int64{}
                fmt.Println(Contain(a, i))
            }

            func testMap() {
                var a = map[int]string{1: "1", 2: "2"}
                fmt.Println(Contain(3, a))

                var b = map[string]int{"1": 1, "2": 2}
                fmt.Println(Contain("1", b))

                var c = map[string][]int{"1": {1, 2}, "2": {2, 3}}
                fmt.Println(Contain("6", c))
            }

            posted on 2017-03-10 14:49 思月行云 閱讀(4371) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            久久国产亚洲高清观看| 久久久久亚洲精品日久生情| 久久精品国产99国产精偷| 久久久青草青青亚洲国产免观| 女人香蕉久久**毛片精品| 国产精品成人久久久久久久| 日日狠狠久久偷偷色综合96蜜桃| 午夜精品久久久久久| 欧美一区二区三区久久综合| 1000部精品久久久久久久久| 久久精品国产91久久麻豆自制| 久久精品无码一区二区三区免费 | 2021久久精品国产99国产精品| 久久无码av三级| 欧美国产成人久久精品| 国产精品久久国产精品99盘| 久久久久99精品成人片牛牛影视| 久久人人爽人人爽人人片av麻烦| 91精品国产9l久久久久| 无码精品久久一区二区三区| 久久久国产乱子伦精品作者| 久久伊人中文无码| 精品人妻久久久久久888| 午夜视频久久久久一区| 国产精品久久毛片完整版| 女同久久| 国产视频久久| 97久久精品国产精品青草| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久国产热这里只有精品| 久久久久久毛片免费播放| 亚洲国产成人精品无码久久久久久综合| 久久精品国产亚洲AV大全| 日韩精品久久久久久久电影| 国产精品久久波多野结衣| 奇米综合四色77777久久| 欧美日韩久久中文字幕| 亚洲精品乱码久久久久久蜜桃| 伊人久久免费视频| 69久久夜色精品国产69| 久久人人爽人人爽人人AV|