make loop

This commit is contained in:
chai2010
2015-12-18 14:49:31 +08:00
parent 9fde1ff772
commit f9ac065e47
106 changed files with 725 additions and 725 deletions

View File

@@ -1,6 +1,6 @@
## 3.5. 字符串
一個字符串是一個不可改變的字節序列. 字符串可以包含任意的數據, 包括字節值0, 但是通常包含人類可讀的文本. 文本字符串通常被解釋爲用UTF8編碼的Unicode碼點(rune)序列, 我們稍後會詳細討論這個問題.
一個字符串是一個不可改變的字節序列. 字符串可以包含任意的數據, 包括字節值0, 但是通常包含人類可讀的文本. 文本字符串通常被解釋爲用UTF8編碼的Unicode碼點(rune)序列, 我們稍後會詳細討論這個問題.
內置的 len 函數可以返迴一個字符串的字節數目(不是rune字符數目), 索引操作 s[i] 返迴第i個字節的字節值, i 必鬚滿足 0 ≤ i< len(s) 條件約束.
@@ -12,23 +12,23 @@ fmt.Println(s[0], s[7]) // "104 119" ('h' and 'w')
Attempting to access a byte outside this range results in a panic:
如果視圖訪問超齣字符串圍的字節將會導panic異常:
如果視圖訪問超齣字符串圍的字節將會導panic異常:
```Go
c := s[len(s)] // panic: index out of range
```
第i個字節不一定是字符串的第i個字符, 因此對於非ASCII字符的UTF8編碼會要兩個或多個字節. 我們簡單下字符的工作方式.
第i個字節不一定是字符串的第i個字符, 因此對於非ASCII字符的UTF8編碼會要兩個或多個字節. 我們簡單下字符的工作方式.
子字符串操作s[i:j]基於原始的s字符串的第i個字節開始到第j個字節(不包含j本身)生成一個新字符串. 生成的子字符串將包含 j-i 個字節.
子字符串操作s[i:j]基於原始的s字符串的第i個字節開始到第j個字節(不包含j本身)生成一個新字符串. 生成的子字符串將包含 j-i 個字節.
```Go
fmt.Println(s[0:5]) // "hello"
```
同樣, 如果索引超齣字符串圍或者j小於i的話將導panic異常.
同樣, 如果索引超齣字符串圍或者j小於i的話將導panic異常.
不管i還是j都可能被忽略, 當它們被忽略時將用0作爲開始位置, len(s) 作爲接受的位置.
不管i還是j都可能被忽略, 當它們被忽略時將用0作爲開始位置, len(s) 作爲接受的位置.
```Go
fmt.Println(s[:5]) // "hello"
@@ -53,20 +53,20 @@ t := s
s += ", right foot"
```
不會導原始的字符串值被改變, 但是 s 將因爲 += 語句持有一個新的字符串值, 但是 t 依然是包含原先的字符串值.
不會導原始的字符串值被改變, 但是 s 將因爲 += 語句持有一個新的字符串值, 但是 t 依然是包含原先的字符串值.
```Go
fmt.Println(s) // "left foot, right foot"
fmt.Println(t) // "left foot"
```
因爲字符串是不可脩改的, 因此試脩改字符串內部數據的操作是被禁止的:
因爲字符串是不可脩改的, 因此試脩改字符串內部數據的操作是被禁止的:
```Go
s[0] = 'L' // compile error: cannot assign to s[0]
```
不變性意味如果兩個字符串共享相同的底層數據是安全的, 這使得製任何長度的字符串代價是低廉的. 同樣, 一個字符串 s 和對應的子字符串 s[7:] 也可以安全地共享相同的內存, 因此字符串切片操作代價也是低廉的. 在這兩種情況下都沒有必要分配新的內存. 圖3.4 演示了一個字符串和兩個字串共享相同的底層數據.
不變性意味如果兩個字符串共享相同的底層數據是安全的, 這使得製任何長度的字符串代價是低廉的. 同樣, 一個字符串 s 和對應的子字符串 s[7:] 也可以安全地共享相同的內存, 因此字符串切片操作代價也是低廉的. 在這兩種情況下都沒有必要分配新的內存. 圖3.4 演示了一個字符串和兩個字串共享相同的底層數據.
{% include "./ch3-05-1.md" %}