golang int64轉(zhuǎn)int的方法
背景:
在cgo中,需要將golang的整數(shù)類型傳到cgo中使用,但是不能直接傳golang的int類型,而應(yīng)該是 int32, 數(shù)值的內(nèi)存長度才能與 c中int 長度一致。 但是有時(shí) golang中獲取到的整型是int64, 但是不能直接使用 int32 強(qiáng)制轉(zhuǎn)換。
以下將提供兩種方法 ,將 golang int64 轉(zhuǎn)換為golang int 。(golang int64轉(zhuǎn)int32方法類似)。
轉(zhuǎn)換方法
1 字符串中轉(zhuǎn)
即將golang int64 先轉(zhuǎn)換wei golang string, 然后將 string 轉(zhuǎn)換為 int
// main.go
package main
import (
"strconv"
"fmt"
"reflect"
)
func main () {
var id64 int64 = 99
// method 1:
strInt64 := strconv.FormatInt(id64, 10)
id16 ,_ := strconv.Atoi(strInt64)
fmt.Println(id16)
fmt.Println(reflect.TypeOf(id16))2 指針類型轉(zhuǎn)換
即獲取golang int64 地址,將其轉(zhuǎn)為int類型,之后讀取該內(nèi)存單元的地址時(shí),會將變量的值解釋為 int類型。
// main.go
package main
import (
"unsafe"
"fmt"
"reflect"
)
func main () {
var id64 int64 = 99
// method 2:
idPointer := (*int)(unsafe.Pointer(&id64))
idd16 := *idPointer
fmt.Println(idd16)
fmt.Println(reflect.TypeOf(idd16))
}說明
第2 種方法較第一種方法不安全
同時(shí)要注意int64范圍, id64數(shù)值不能超過最大值或者低于最小值,值范圍可參考,https://studygolang.com/articles/6566
到此這篇關(guān)于golang int64轉(zhuǎn)int的文章就介紹到這了,更多相關(guān)golang int64轉(zhuǎn)int內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Goland IDEA項(xiàng)目多開設(shè)置方式
這篇文章主要介紹了Goland IDEA項(xiàng)目多開設(shè)置方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Go實(shí)現(xiàn)簡單的數(shù)據(jù)庫表轉(zhuǎn)結(jié)構(gòu)體詳解
這篇文章主要為大家介紹了Go實(shí)現(xiàn)簡單的數(shù)據(jù)庫表轉(zhuǎn)結(jié)構(gòu)體詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
Go?Singleflight導(dǎo)致死鎖問題解決分析
這篇文章主要為大家介紹了Go?Singleflight導(dǎo)致死鎖問題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
Golang的Fork/Join實(shí)現(xiàn)代碼
Fork/Join本質(zhì)上是一種任務(wù)分解,將一個(gè)很大的任務(wù)分解成若干個(gè)小任務(wù),然后再對小任務(wù)進(jìn)一步分解,直到最小顆粒度,然后并發(fā)執(zhí)行,對Golang的Fork/Join實(shí)現(xiàn)代碼感興趣的朋友跟隨小編一起看看吧2023-01-01
Go?gRPC進(jìn)階教程gRPC轉(zhuǎn)換HTTP
這篇文章主要為大家介紹了Go?gRPC進(jìn)階教程gRPC轉(zhuǎn)換HTTP教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
go語言計(jì)算兩個(gè)時(shí)間的時(shí)間差方法
這篇文章主要介紹了go語言計(jì)算兩個(gè)時(shí)間的時(shí)間差方法,涉及Python操作時(shí)間的技巧,需要的朋友可以參考下2015-03-03
Golang?Compare?And?Swap算法詳細(xì)介紹
CAS算法是一種有名的無鎖算法。無鎖編程,即不使用鎖的情況下實(shí)現(xiàn)多線程之間的變量同步,也就是在沒有線程被阻塞的情況下實(shí)現(xiàn)變量的同步,所以也叫非阻塞同步Non-blocking?Synchronization2022-10-10

