go中的变量类型转换

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

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
返回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)。

相关文档
最新文档