Go中的各种变量类型转换

从PHP转向GO,最不能适应的是GO是强类型语言,变量的申明需要指定其类型,相同的变量之间才可以做算术、关系、逻辑等运算。

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
返回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类型

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)
其他类型 可转换到string后,再进行转换

发表评论

电子邮件地址不会被公开。 必填项已用*标注

您可以使用这些HTML标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>