<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                #### **數組介紹** 數組可以存放多個同一類型數據。數組也是一種數據類型,在Go中,數組是值類型。 看一個問題 一個養雞場有6只雞,它們的體重分別是3kg,5kg,1kg,3.4kg,2kg,50kg。請問這六只雞的總體重是多少?平均體重是多少?請你編一個程序。=》數組 ![](https://img.kancloud.cn/61/a8/61a8f3e18be12e0936353091330a4372_722x473.png) 對上面代碼的總結 1)使用數組來解決問題,程序的可維護性增加. 2)而且方法代碼更加清晰,也容易擴展。 **數組定義和內存布局** var數組名\[數組大小\]數據類型 vara\[5\]int 初值a\[0\]=1a\[1\]=30.... 數組在內存布局(重要) ![](https://img.kancloud.cn/1a/11/1a11c6485d624a78a6e7521e0eb618c0_769x257.png) 對上圖的總結 1)數組的地址可以通過數組名來獲取&intArr 2)數組的第一個元素的地址,就是數組的首地址 3)數組的各個元素的地址間隔是依據數組的類型決定,比如int64->8int32->4.. ![](https://img.kancloud.cn/0e/9f/0e9fa0df069f6faaf02b4bf77e3715be_743x292.png) **數組的使用** 數組名\[下標\]比如:你要使用a數組的第三個元素a\[2\] **四種初始化數組的方式** ![](https://img.kancloud.cn/c0/90/c09028a66c32c4bbed4043641c4cc085_663x324.png) **數組的遍歷** 1:常規遍歷:for循環 2:for-range結構遍歷這是Go語言一種獨有的結構,可以用來遍歷訪問數組的元素。 ![](https://img.kancloud.cn/54/41/5441286bb5c7618dadd14ae9efcab27d_925x290.png) ![](https://img.kancloud.cn/c7/6c/c76c2b8e854e9b74fea38829d622ead0_716x417.png) **數組使用的注意事項和細節** 1)數組是多個相同類型數據的組合,一個數組一旦聲明/定義了,其長度是固定的,不能動態變化 ![](https://img.kancloud.cn/89/d3/89d337df5b3b53da14015fe975adf082_701x365.png) 2) var arr \[\]int 這時 arr 就是一個 slice 切片,切片后面專門講解,不急哈. 3) 數組中的元素可以是任何數據類型,包括值類型和引用類型,但是不能混用。 4) 數組創建后,如果沒有賦值,有默認值(零值) 數值類型數組:默認值為 0 字符串數組: 默認值為 "" bool 數組: 默認值為 false ![](https://img.kancloud.cn/81/3d/813de0d78dd18cf4b6e7578b2747d848_654x220.png) 5) 使用數組的步驟 1\. 聲明數組并開辟空間 2 給數組各個元素賦值(默認零值) 3 使用數組 6) 數組的下標是從 0 開始的 ![](https://img.kancloud.cn/6e/d3/6ed3d3356e549ceb9ef4157c37c66747_612x124.png) 7) 數組下標必須在指定范圍內使用,否則報 panic:數組越界,比如 var arr \[5\]int 則有效下標為 0-4 8) Go 的數組屬值類型, 在默認情況下是值傳遞, 因此會進行值拷貝。數組間不會相互影響 ![](https://img.kancloud.cn/10/2e/102e6d80aa08244f28037c42cedf419c_814x244.png) 9) 如想在其它函數中,去修改原來的數組,可以使用引用傳遞(指針方式) ![](https://img.kancloud.cn/ba/6b/ba6b1b69b097cde416c383d9bf1260a3_839x244.png) 10) 長度是數組類型的一部分,在傳遞函數參數時 需要考慮數組的長度,看下面案例 ![](https://img.kancloud.cn/f4/96/f496adfafe051f463dfcacd1199ceb29_805x305.png) #### **切片** 1) 切片的英文是 slice 2) 切片是數組的一個引用,因此切片是引用類型,在進行傳遞時,遵守引用傳遞的機制。 3) 切片的使用和數組類似,遍歷切片、訪問切片的元素和求切片長度 len(slice)都一樣。 4) 切片的長度是可以變化的,因此切片是一個可以動態變化數組。 5) 切片定義的基本語法: var 切片名 []類型 比如:var a [] int **快速入門** ![](https://img.kancloud.cn/7f/7c/7f7cfdaf05cf573d37eca9822f38bd72_736x548.png) **切片在內存中形式(重要)** ![](https://img.kancloud.cn/43/37/43379ba923632d8da09c3605c779f464_923x179.png) 對上面的分析圖總結 1. slice 的確是一個引用類型 2. slice 從底層來說,其實就是一個數據結構(struct 結構體) ``` type slice struct { ptr *[2]int len int cap int } ``` **切片的使用** 第一種方式:定義一個切片,然后讓切片去引用一個已經創建好的數組,比如前面的案例就是這樣的。 第二種方式:通過 make 來創建切片. 基本語法:var 切片名 []type = make([]type, len, [cap]) 參數說明: type: 就是數據類型 len : 大小 cap :指定切片容量,可選, 如果你分配了 cap,則要求 cap>=len. ![](https://img.kancloud.cn/6c/3a/6c3a2a228a0ab77aed5d909465caa7bf_924x228.png) 對上面代碼的小結: 1) 通過 make 方式創建切片可以指定切片的大小和容量 2) 如果沒有給切片的各個元素賦值,那么就會使用默認值\[int , float=> 0 string =>”” bool => false\] 3) 通過 make 方式創建的切片對應的數組是由 make 底層維護,**對外不可見,即只能通過 slice 去 訪問各個元素.** 第 3 種方式:定義一個切片,直接就指定具體數組,使用原理類似 make 的方式 ![](https://img.kancloud.cn/c7/43/c743455989afbc7e17b981f4da0d62fa_754x210.png) 方式 1 和方式 2 的區別(面試) ![](https://img.kancloud.cn/63/73/637391d677207364888089ecd5add416_625x201.png) **切片的遍歷** 切片的遍歷和數組一樣,也有兩種方式 for 循環常規方式遍歷 for-range 結構遍歷切片 ![](https://img.kancloud.cn/c2/08/c20849a3f30466570d61416676bd683c_694x343.png) **切片的使用的注意事項和細節討論** 1) 切片初始化時 var slice = arr\[startIndex:endIndex\] 說明:從 arr 數組下標為 startIndex,取到 下標為 endIndex 的元素(不含 arr\[endIndex\])。 2) 切片初始化時,仍然不能越界。范圍在 \[0-len(arr)\] 之間,但是可以動態增長. var slice = arr\[0:end\] 可以簡寫 var slice = arr\[:end\] var slice = arr\[start:len(arr)\] 可以簡寫: var slice = arr\[start:\] var slice = arr\[0:len(arr)\] 可以簡寫: var slice = arr\[:\] 3) cap 是一個內置函數,用于統計切片的容量,即最大可以存放多少個元素。 4) 切片定義完后,還不能使用,因為本身是一個空的,需要讓其引用到一個數組,或者 make 一 個空間供切片來使用 5) 切片可以繼續切片\[案例演示\] ![](https://img.kancloud.cn/cd/e6/cde62b84c44012cb9215015ca8737f85_687x395.png) 6) 用 append 內置函數,可以對切片進行動態追加(注意直接下標得方式長度有限制長度為切片初始化的默認長度超過長度限制) ![](https://img.kancloud.cn/68/07/68074cd79beceba535909ff05ce9bd1a_735x207.png) ![](https://img.kancloud.cn/dc/8e/dc8eaeef4ae9f17fe5b9a29aeba75be1_732x256.png) 切片 append 操作的底層原理分析: 切片 append 操作的本質就是對數組擴容 go 底層會創建一下新的數組 newArr(安裝擴容后大小) 將 slice 原來包含的元素拷貝到新的數組 newArr slice 重新引用到 newArr 注意 newArr 是在底層來維護的 ![](https://img.kancloud.cn/76/78/76784ae8f64eba791e51fe6a0dfc0173_623x217.png) 7) 切片的拷貝操作 切片使用 copy 內置函數完成拷貝,舉例說明,程序員不可見 ![](https://img.kancloud.cn/c0/38/c0384630176768c20d1ab6301b1d0d85_667x201.png) 對上面代碼的說明: (1) copy(para1, para2) 參數的數據類型是切片 (2) 按照上面的代碼來看, slice4 和 slice5 的數據空間是獨立,相互不影響,也就是說 slice4\[0\]= 999, slice5\[0\] 仍然是 1 8) 關于拷貝的注意事項 ![](https://img.kancloud.cn/d6/63/d66317cae9808a57ea4cb5f341109e97_870x288.png) 9) 切片是引用類型,所以在傳遞時,遵守引用傳遞機制。看兩段代碼,并分析底層原理 ![](https://img.kancloud.cn/20/91/209162436859828eb7f682e238b134d0_801x300.png) **string 和 slice** 1) string 底層是一個 byte 數組,因此 string 也可以進行切片處理 案例演示: ![](https://img.kancloud.cn/65/5e/655ee1aa7140a2d5b627dea95951124a_598x211.png) 2) string 和切片在內存的形式,以 "abcd" 畫出內存示意圖 ![](https://img.kancloud.cn/d8/db/d8db45d330733207f86f49b2f2c84680_669x278.png) 3) string 是不可變的,也就說不能通過 str\[0\] = 'z' 方式來修改字符串 ![](https://img.kancloud.cn/e5/99/e59980864e08cff2a3b38082228a547f_677x74.png) 4) 如果需要修改字符串,可以先將 string -> []byte / 或者 []rune -> 修改 -> 重寫轉成 string ![](https://img.kancloud.cn/bd/47/bd47a8498b40d476465e719084002901_761x327.png) 編寫一個函數 fbn(n int) ,要求完成 1) 可以接收一個 n int 2) 能夠將斐波那契的數列放到切片中 3) 提示, 斐波那契的數列形式: arr[0] = 1; arr[1] = 1; arr[2]=2; arr[3] = 3; arr[4]=5; arr[5]=8 ![](https://img.kancloud.cn/17/a9/17a9de2cf3d18e777ea1f0f0a176b7a2_750x782.png) **二維數組** ![](https://img.kancloud.cn/c4/0b/c40b487febbe7bfe3180585991b45809_722x637.png) **使用方式 1: 先聲明/定義,再賦值** 語法: var 數組名 [大小] [大小\]類型 比如: var arr [2][3]int , 再賦值。 使用演示 二維數組在內存的存在形式(重點) 解釋:指針是16進制顯示,兩個指針相差24個字節因為 int占8個3*8地址為第二個指針 ![](https://img.kancloud.cn/07/26/07265f826b48da06dfa199282946c953_831x265.png) ![](https://img.kancloud.cn/d4/f0/d4f0f5da4a11f406894f5a0a31302940_804x252.png) **使用方式 2: 直接初始化** 聲明:var 數組名 \[大小\]\[大小\]類型 \= \[大小\]\[大小\]類型{{初值..},{初值..}} 賦值(有默認值,比如 int 類型的就是 0) ![](https://img.kancloud.cn/c3/f1/c3f152868cd3ca1dae0c65c2717acb36_527x91.png) **二維數組在聲明/定義時也對應有四種寫法\[和一維數組類似\]** var 數組名 \[大小\]\[大小\]類型 \= \[大小\]\[大小\]類型{{初值..},{初值..}} var 數組名 \[大小\]\[大小\]類型 \= \[...\]\[大小\]類型{{初值..},{初值..}} var 數組名 \= \[大小\]\[大小\]類型{{初值..},{初值..}} var 數組名 \= \[...\]\[大小\]類型{{初值..},{初值..}} **二維數組的遍歷** 雙層 for 循環完成遍歷 for-range 方式完成遍歷 ![](https://img.kancloud.cn/58/78/5878133070c5fc2323d9ec07d0346924_617x372.png)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看