日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Go語言中基本數據類型的相互轉換詳解_Golang

作者:甜點cc ? 更新時間: 2022-12-01 編程語言

基本數據類型的相互轉換

Go在不同類型的變量之間賦值時需要顯示轉換,不能自動轉換

基本語法

表達式?T(v): 將值v轉換成類型T

T就是數據類型: int32, int64, float32...

v就是需要轉換的變量

1.不考慮溢出的情況下,類型轉換不會改變數值大小

var i int8 = 100
var n int32 = int32(i)
fmt.Println(i, n)

輸出:

100 100

2.不支持隱式轉換, 代碼檢查不通過,編譯不能通過

var n1 int32 = 30
var n2 int16
var n3 int64

n2 = 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) + 2
n3 = int64(n1) + 2
fmt.Println(n1, n2, n3)

輸出:

30 32 32

3.溢出測試

var n1 int32 = 12
var n2 int8
var n3 int8
n2 = int8(n1) + 127
n3 = int8(n1) + 128 // 128代碼檢查報錯, constant 128 overflows int8
fmt.Println(n1, n2, n3)

修改如下:

這時候語言檢查是沒有問題的。計算結果超出類型范圍,溢出處理

n2 = int8(n1) + 127 
n3 = int8(n1) + 120
fmt.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 = 99
var num4 float64 = 23.456
var b2 bool = true
var num5 int = 4567

1.func FormatBool(b bool) string

str = strconv.FormatBool(b)
fmt.Printf("%T %q\n", str, str) // string "true"

2.func FormatInt(i int64, base int) string

str = strconv.FormatInt(int64(num3), 10)
fmt.Printf("%T %q\n", str, str) // string "99"

3.func FormatUint(i uint64, base int) string

4.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"

5.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?包的函數

1.func ParseBool(str string) (value bool, err error)

  • 返回兩個值,一個是轉換的bool值,一個是error
  • 我們只需要拿到第一個返回值, 第二個忽略
var str string = "true"
var b bool

b, _ = strconv.ParseBool(str)
fmt.Printf("%T %v\n", b, b) // bool true

以下三個返回值是64為,必須用64位的類型去接收,如果需要32位,則手動轉

2.func ParseInt(s string, base int, bitSize int) (i int64, err error)

var str2 string = "123"
var n int64
var n2 int
n, _ = strconv.ParseInt(str2, 10, 64)
n2 = int(n)  // int64轉成int
fmt.Printf("%T %v\n", n, n)    // int64 123
fmt.Printf("%T %v\n", n2, n2)  // int 123

3.func ParseUint(s string, base int, bitSize int) (n uint64, err error)

同?ParseInt()

4.func ParseFloat(s string, bitSize int) (f float64, err error)

var str3 string = "123.456"
var f1 float64
f1, _ = strconv.ParseFloat(str3, 64)
fmt.Printf("%T %v\n", f1, f1)   // float64 123.456

5.注意, 不能正確識別的,默認轉成零值

var str4 string = "hello"
var f2 float64
var b2 bool = true     // 不管原來是什么值,如果沒有轉成功,就會置為false
f2, _ = strconv.ParseFloat(str4, 64)
fmt.Printf("%T %v\n", f2, f2)
b2, _ = strconv.ParseBool(str4) // float64 0
fmt.Printf("%T %v\n", b2, b2)   // bool false

原文鏈接:https://www.cnblogs.com/all-smile/p/16824141.html

欄目分類
最近更新