go中的变量类型转换
原文:Go中的各种变量类型转换
Go中的各种变量类型转换
从PHP转向GO,最不能适应的是GO是强类型语言,变量的申明需要指定其类型,相同的变量之间才可以做算术、关系、逻辑等运算。
一、string类型
int int8 int16 int32 int64 |
string转换成这5种类型,需要先使用 strconv.ParseInt(s,10,64), 转换成相对应的int64,然后使用强制转换。例如: r,_ := strconv.Parseint(“123″,10,8) int8(r)func ParseInt(s string, base int, bitSize int) (i int64, err error) 返回字符串表示的整数值,接受正负号。 base指定进制(2到36),如果base为0,则会从字符串前置判断,”0x”是16进制,”0″是8进制,否则是10进制; bitSize指定结果必须能无溢出赋值的整数类型,0、8、16、32、64 分别代表 int、int8、int16、int32、int64;返回的err是*NumErr类型的,如果语法有误,err.Error = ErrSyntax;如果结果超出类型范围err.Error = ErrRange。从上面的描述中,也可以得知,该方法还可以用于转换2进制、8进制、16进制到10进制,例如: strconv.ParseInt(“1110110″,2,64),返回结果:118特殊的方法: func Atoi(s string) (i int, err error) Atoi是ParseInt(s, 10, 0)的简写。 |
uint uint8 uint16 uint32 uint64 |
同上,ParseUint类似ParseInt但不接受正负号,用于无符号整型 |
float32 float64 |
用法同上,先使用 strconv.ParseFloat(s,64),然后强制转换成相对应的类型。func ParseFloat(s string, bitSize int) (f float64, err error) 解析一个表示浮点数的字符串并返回其值。 如果s合乎语法规则,函数会返回最为接近s表示值的一个浮点数(使用IEEE754规范舍入)。bitSize指定了期望的接收类型,32是float32(返回值可以不改变精确值的赋值给float32),64是float64;返回值err是*NumErr类型的,语法有误的,err.Error=ErrSyntax;结果超出表示范围的,返回值f为±Inf,err.Error= ErrRange。注意:使用float类型一定要注意其精度 |
[]byte | []byte(s) ,而从字节切片转换成string,则使用 string(b),从这里可以看出[]byte和string可以使用强制转换。 |
rune | 同上,先使用 strconv.ParseInt(s,10,64),转换成int64,然后使用强制转换 r ,_ := strconv.ParseInt(s,10,64) rune(r) |
bool | bool, err := strconv.ParseBool(s) 返回字符串表示的bool值。它接受1、0、t、f、T、F、true、false、True、False、TRUE、FALSE;否则返回错误。 |
二、bool类型
string | r := strconv.FormatBool(s) func FormatBool(b bool) string 根据b的值返回”true”或”false”。 |
其他类型 | 一般情况很少将bool转换成字符以外的类型,如果有可将bool类型转换成string后,再进行转换,或者采用switch的判断逻辑,反正bool就2种值类型。 |
三、int、int8、int16、int32、int64类型
string | 将这5种类型转换到string类型,需要先使用强制转换到int64,再使用strconv.FormatInt(int64(s),10)
func FormatInt(i int64, base int) string 同理:该方法也可以将这5种类型,转换成2进制,8进制,10进制的字符串。 特殊方法: |
uint uint8 uint16 uint32 uint64 float32 float64 |
使用强制转换。 var s = 35 uint(s) uint8(s) |
其他类型 | 可转换到string后,再进行转换 |
四、uint、uint8、uint16、uint32、uint64类型
string | 将这5种类型转换到string类型,需要先使用强制转换到uint64,再使用strconv.FormatUint(uint64(s),10)
func FormatUint(i uint64, base int) string 同理:该方法也可以将这5种类型,转换成2进制,8进制,10进制的字符串。 |
int int8 int16 int32 int64 float32 float64 |
使用强制转换。 var s = 35 int(s) int8(s) float64(s) |
其他类型 | 可转换到string后,再进行转换 |
五、float32、float64类型
string | var s = 111.123456 r := strconv.FormatFloat(float64(s),’f’,3,32)func FormatFloat(f float64, fmt byte, prec, bitSize int) string 函数将浮点数表示为字符串并返回。 bitSize表示f的来源类型(32:float32、64:float64),会据此进行舍入。 fmt表示格式:’f’(-ddd.dddd)、’b’(-ddddp±ddd,指数为二进制)、’e’(-d.dddde±dd,十进制指数)、’E’(-d.ddddE±dd,十进制指数)、’g’(指数很大时用’e’格式,否则’f’格式)、’G’(指数很大时用’E’格式,否则’f’格式)。 prec控制精度(排除指数部分):对’f’、’e’、’E’,它表示小数点后的数字个数;对’g’、’G’,它控制总的数字个数。如果prec 为-1,则代表使用最少数量的、但又必需的数字来表示f。 |
int int8 int16 int32 int64 uint uint8 uint16 uint32 uint64 |
使用强制转换。 var s = 35 int(s) int8(s) |