zoukankan      html  css  js  c++  java
  • 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
    返回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)
  • 相关阅读:
    MSP430F149学习之路——蓝牙模块
    MSP430F149学习之路——SPI
    MSP430推荐网站
    MSP430F149学习之路——UART
    MSP430F149学习之路——比较器Comparaor_A
    MSP430F149学习之路——PWM信号
    MSP430F149学习之路——捕获/比较模式
    MSP430F149学习之路——时钟1
    CUDA学习笔记(三)——CUDA内存
    CUDA学习笔记(一)——CUDA编程模型
  • 原文地址:https://www.cnblogs.com/-wenli/p/12318719.html
Copyright © 2011-2022 走看看