设为首页 加入收藏

TOP

Golang 强制类型转换
2014-11-24 01:40:30 来源: 作者: 【 】 浏览:1
Tags:Golang 强制 类型 转换

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 := (*MyTemplate)(unsafe.Pointer(t))
p.name = "Bar" // 关键在这里,突破私有成员
fmt.Println(p, t)
}


相关阅读:


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Golang 单例模式 singleton patte.. 下一篇Golang 模拟Java超类型(abstract ..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: