基本数据类型的相互转换Go在不同类型的变量之间赋值时需要显示转换,不能自动转换
基本语法表达式 T(v)
: 将值v转换成类型T
T就是数据类型: int32, int64, float32...
v就是需要转换的变量
- 不考虑溢出的情况下,类型转换不会改变数值大小
var i int8 = 100var n int32 = int32(i)fmt.Println(i, n)
输出:100 100
- 不支持隐式转换, 代码检查不通过,编译不能通过
var n1 int32 = 30var n2 int16var n3 int64n2 = n1 + 2 // n1为int32, n1 + 2得到的还是int32类型, 而n2是int16类型n3 = n1 + 2 // 同上fmt.Println(n1, n2, n3)
cannot use n1 + 2 (value of type int32) as int16 value in assignment修改如下:显示转换
n1为int32, n2为int16, 所以先把加数n1转换成int16, 再做加法
n2 = int16(n1) + 2n3 = int64(n1) + 2fmt.Println(n1, n2, n3)
【Go | 基本数据类型的相互转换】输出:30 32 32
- 溢出测试
var n1 int32 = 12var n2 int8var n3 int8n2 = int8(n1) + 127n3 = int8(n1) + 128 // 128代码检查报错, constant 128 overflows int8fmt.Println(n1, n2, n3)
修改如下:这时候语言检查是没有问题的 。计算结果超出类型范围 , 溢出处理
n2 = int8(n1) + 127n3 = int8(n1) + 120fmt.Println(n1, n2, n3)// 输出 12 -117 -124
文章插图
小知识如果引入一个包没有使用,但是又不想删除,可以再前面加一个
_
表示忽略(只初始化,不使用)package main// import "unsafe"// import "fmt"import ( _ "fmt" _ "unsafe")func main() {}
基本数据类型和string的转换方法一:fmt.Sprintf("%参数", 表达式)func main() { var n int = 10 var n1 float64 = 12.56 var b bool = false var myChar byte = 'h' var str string str = fmt.Sprintf("%d", n) fmt.Printf("%T %v\n", str, str) // string 10 str = fmt.Sprintf("%f", n1) fmt.Printf("%T %v\n", str, str) // string 12.560000 str = fmt.Sprintf("%t", b) fmt.Printf("%T %q\n", str, str) // string "false" str = fmt.Sprintf("%q", myChar) fmt.Printf("%T %q\n", str, str) // string "'h'"}
方法二:使用 strconv
包的函数var num3 int = 99var num4 float64 = 23.456var b2 bool = truevar num5 int = 4567
- func FormatBool(b bool) string
str = strconv.FormatBool(b)fmt.Printf("%T %q\n", str, str) // string "true"
- func FormatInt(i int64, base int) string
str = strconv.FormatInt(int64(num3), 10)fmt.Printf("%T %q\n", str, str) // string "99"
- func FormatUint(i uint64, base int) string
- func FormatFloat(f float64, fmt byte, prec, bitSize int) string
- 4个参数描述: f, fmt(表示格式), prec(控制精度), bitSize(表示f的来源类型(32:float32、64:float64))
str = strconv.FormatFloat(float64(num4), 'f', 10, 64)fmt.Printf("%T %q\n", str, str) // string "23.4560000000"
func Itoa(i int) string
str = strconv.Itoa(num5)fmt.Printf("%T %q\n", str, str) // string "4567"
string和基本数据类型转换注意事项:转成基本数据类型的时候,确保string类型能够转成有效的数据,比如把"123"转成整数123,
不能把别的字符串 , 类似"hello",转成整数 , Golang直接将其转成默认零值0
方法: 使用
strconv
包的函数- func ParseBool(str string) (value bool, err error)
- 返回两个值,一个是转换的bool值,一个是error
- 我们只需要拿到第一个返回值, 第二个忽略
var str string = "true"var b boolb, _ = strconv.ParseBool(str)fmt.Printf("%T %v\n", b, b) // bool true
以下三个返回值是64为,必须用64位的类型去接收 , 如果需要32位,则手动转- func ParseInt(s string, base int, bitSize int) (i int64, err error)
var str2 string = "123"var n int64var n2 intn, _ = strconv.ParseInt(str2, 10, 64)n2 = int(n)// int64转成intfmt.Printf("%T %v\n", n, n)// int64 123fmt.Printf("%T %v\n", n2, n2)// int 123
- func ParseUint(s string, base int, bitSize int) (n uint64, err error)
ParseInt()
- func ParseFloat(s string, bitSize int) (f float64, err error)
var str3 string = "123.456"var f1 float64f1, _ = strconv.ParseFloat(str3, 64)fmt.Printf("%T %v\n", f1, f1)// float64 123.456
- 注意,不能正确识别的,默认转成零值
var str4 string = "hello"var f2 float64var b2 bool = true// 不管原来是什么值,如果没有转成功 , 就会置为falsef2, _ = strconv.ParseFloat(str4, 64)fmt.Printf("%T %v\n", f2, f2)b2, _ = strconv.ParseBool(str4) // float64 0fmt.Printf("%T %v\n", b2, b2)// bool false
推荐阅读
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 二 『现学现忘』Git分支 — 41、分支基本操作
- 一 Redis数据结构-Redis的数据存储及String类型的实现
- 德州扑克基本玩法(德州扑克新手必学)
- Oracle数据库的两种授权收费方式介绍!
- python3使用mutagen进行音频元数据处理
- 利用inotify和rsync服务实现数据实时同步
- 一 『现学现忘』Git分支 — 40、分支基本操作
- 使用LEFT JOIN 统计左右存在的数据
- Redis 01: 非关系型数据库 + 配置Redis
- Redis 02: redis基础知识 + 5种数据结构 + 基础操作命令