golang 强制类型转换

golang 强制类型转换,第1张

概述Go语言是个强类型语言。也就是说Go对类型要求严格,不同类型不能进行赋值 *** 作。指针也是具有明确类型的对象,进行严格类型检查。下面的代码会产生编译错误 package main import ( "fmt") func main() { u := uint32(32)

Go语言是个强类型语言。也就是说Go对类型要求严格,不同类型不能进行赋值 *** 作。指针也是具有明确类型的对象,进行严格类型检查。下面的代码会产生编译错误


package main                         import (    "fmt")                            func main() {    u := uint32(32)    i := int32(1)    fmt.Println(&u,&i) // 打印出地址    p := &i // p 的类型是 *int32    p = &u // &u的类型是 *uint32,于 p 的类型不同,不能赋值       p = (*int32)(&u) // 这种类型转换语法也是无效的     fmt.Println(p)}

unsafe 包提供的Pointer方法可以完成这个任务


package main         import (    "fmt"    "unsafe")         func main() {    u := uint32(32)    i := int32(1)    fmt.Println(&u,&i)    p := &i    p = (*int32)(&u)    p = (*int32)(unsafe.Pointer(&u))    fmt.Println(p)}



补充:实际使用中unsafe可用场景很少,稍微复杂一点的结构,比如struct,unsafe根本不能适用,正确的方法还是要靠 type assertion

ps:发现一种用法,看代码

package main   import (    "fmt"    "text/template"    "unsafe")   // MyTemplate 定义和 template.Template 只是形似type MyTemplate struct {    name       string    parseTree  *unsafe.Pointer    common     *unsafe.Pointer    leftDelim  string    rightDelim string}   func main() {    t := template.New("Foo")    p := (*My<span></span>Template<span></span>)(unsafe.Pointer(t))    p.name = "bar" // 关键在这里,突破私有成员    fmt.Println(p,t)}
总结

以上是内存溢出为你收集整理的golang 强制类型转换全部内容,希望文章能够帮你解决golang 强制类型转换所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1291801.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-10
下一篇 2022-06-10

发表评论

登录后才能评论

评论列表(0条)

保存