赞
踩
vFloat32 := float32(vInt)
vFloat64 := float64(vInt)
package main
import "fmt"
func main() {
var AAA int = 17
var BBB int = 5
var CCC float32
CCC = float32(AAA)/float32(BBB)
fmt.Printf("CCC 的值为: %f\n",CCC)
}
说明:定义int型的 AAA /BBB ,float32型的 CCC。
CCC 计算时 给AAA和BBB转换类型为float32。
输出:
CCC 的值为: 3.400000
vInt := int(vFloat64)
vInt := int(vFloat32)
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var stringA string
intA,_:=strconv.Atoi(stringA)
fmt.Println("intA 的数据类型是:",reflect.TypeOf(intA))
}
输出:
intA 的数据类型是: int
字串的值按十进制算,转换为int类型
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var stringA = "12"
intA,_ := strconv.ParseInt(stringA, 10, 64)
fmt.Println("intA 的数据类型是:",reflect.TypeOf(intA),"值为:",intA)
}
输出
intA 的数据类型是: int64 值为: 12
说明:
strconv.ParseInt()
中第二个参数是字串值按多少进制算。
如示例中10 ,只得是字串按10进制计。
如果字串的值是16进制算,转换为int格式
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var stringA = "12"
intA,_ := strconv.ParseInt(stringA, 16, 64)
fmt.Println("intA 的数据类型是:",reflect.TypeOf(intA),"值为:",intA)
}
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var stringA = "12"
float64A,_ := strconv.ParseFloat(stringA,32)
fmt.Println("float64A 的数据类型是:",reflect.TypeOf(float64A),"值为:",float64A)
}
输出
float64A 的数据类型是: float64 值为: 12
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var intA = 12
stringA := strconv.Itoa(intA)
fmt.Println("stringA 的数据类型是:",reflect.TypeOf(stringA),"值为:",stringA)
}
输出
stringA 的数据类型是: string 值为: 12
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var int64A int64 = 12.0000000
stringA := strconv.FormatInt(int64A, 10)
fmt.Println("stringA 的数据类型是:",reflect.TypeOf(stringA),"值为:",stringA)
}
输出
stringA 的数据类型是: string 值为: 12
说明:
strconv.FormatInt
第二个参数是转换后的字串是x进制显示,如二进制显示:
func main() {
var int64A int64 = 12.0000000
stringA := strconv.FormatInt(int64A, 2)
fmt.Println("stringA 的数据类型是:",reflect.TypeOf(stringA),"值为:",stringA)
}
输出为:
stringA 的数据类型是: string 值为: 1100
package main
import (
"fmt"
"reflect"
"strconv"
)
func main() {
var float64A float64 = 0.123456789
stringA := strconv.FormatFloat(float64A, 'f', 5, 64)
fmt.Println("stringA 的数据类型是:",reflect.TypeOf(stringA),"值为:",stringA)
}
说明:
strconv.FormatFloat()
的
第二个参数:表示计数形似,f
表示不按指数形式计。
第三个参数:表示小数点后保留几位,-1 表示按原来位数
输出
stringA 的数据类型是: string 值为: 0.12346
userId
是从session中取到的用户Id,类型是interface。 val,ok:= userId.(float64)
if ok {
……
}
完整代码如下:
if identity, ok := c.Get("identity"); ok { if identityMap, ok := identity.(map[string]interface{}); ok { fmt.Printf("identityMap: %+v\n", identityMap) if userId, ok := identityMap["UserId"]; ok { val,ok:= userId.(float64) if ok { userIdInt = int(val) } fmt.Println("里边 userIdInt :",userIdInt) }else { fmt.Printf("No UserId\n") } }else { fmt.Printf("Not a map: %+v\n", identityMap) } }else { fmt.Println("identify not found") }
Astring := ASliceByte[:]
var ASliceByte = []byte(Astring)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。