内容简介:注:本文是对在Go中string是由不可变的字节数组构成的。一旦赋值,就不能修改字符串的值。例如In
注:本文是对 golang-101-hacks 中文翻译。
在 Go 中string是由不可变的字节数组构成的。一旦赋值,就不能修改字符串的值。例如
In Go
, string is an immutable array of bytes. So if created, we can't change its value. E.g.:
package main func main() { s := "Hello" s[0] = 'h' }
编译结果会提示错误:
The compiler will complain:
cannot assign to s[0]
对字符串的修改可以将其转换为“byte”数组。但是实际上您并没有对原始字符串进行修改操作,改变的只是一个原始字符串的副本。
To modify the content of a string, you could convert it to a byte
array. But in fact, you do not
operate on the original string, just a copy:
package main import "fmt" func main() { s := "Hello" b := []byte(s) b[0] = 'h' fmt.Printf("%s\n", b) }
运行结果
The result is like this:
hello
Go使用的是UTF-8的编码方式,函数len的结果是当前字符字节的长度而不是字符长度
Since Go
uses UTF-8
encoding, you must remember the len
function will return the string's byte number, not character number:
package main import "fmt" func main() { s := "日志log" fmt.Println(len(s)) }
执行结果是
The result is:
由于每个中文占3个字节,上面的例子中s字符串有5个字符和9个字节组成的
Because each Chinese character occupied 3
bytes, s
in the above example contains 5
characters and 9
bytes.
对字符串执行 for ... range
循环语句可以获取到每个字符
If you want to access every character, for ... range
loop can give a help:
package main import "fmt" func main() { s := "日志log" for index, runeValue := range s { fmt.Printf("%#U starts at byte position %d\n", runeValue, index) } }
执行结果
U+65E5 '日' starts at byte position 0 U+5FD7 '志' starts at byte position 3 U+006C 'l' starts at byte position 6 U+006F 'o' starts at byte position 7 U+0067 'g' starts at byte position 8
参考
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python for Data Analysis
Wes McKinney / O'Reilly Media / 2012-11-1 / USD 39.99
Finding great data analysts is difficult. Despite the explosive growth of data in industries ranging from manufacturing and retail to high technology, finance, and healthcare, learning and accessing d......一起来看看 《Python for Data Analysis》 这本书的介绍吧!