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)

boolbool, err := strconv.ParseBool(s)

返回字符串表示的bool值。它接受1、0、t、f、T、F、true、false、True、False、TRUE、FALSE;否则返回错误。

二、bool类型

stringr := 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

返回i的base进制的字符串表示。base 必须在2到36之间,结果中会使用小写字母’a’到’z’表示大于10的数字。

同理:该方法也可以将这5种类型,转换成2进制,8进制,10进制的字符串。

var s = 35

r := strconv.FormatInt(int64(s),2)

fmt.Println(r) // 100011

特殊方法:

func Itoa(i int) string

Itoa是FormatInt(i, 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

是FormatInt的无符号整数版本。

同理:该方法也可以将这5种类型,转换成2进制,8进制,10进制的字符串。

var s = 111

r := strconv.FormatUint(uint64(s),2)

fmt.Println(r) // 1101111

int

int8

int16

int32

int64

float32

float64

使用强制转换。

var s = 35

int(s)

int8(s)

float64(s)

其他类型可转换到string后,再进行转换

五、float32、float64类型

stringvar 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)