登录
首页 >  Golang >  Go问答

更有效的 Go 中检查字节序的方法

来源:stackoverflow

时间:2024-03-23 22:03:32 383浏览 收藏

本文讨论了在 Go 语言中确定字节顺序的方法。虽然使用不安全的指针可以解决问题,但它存在潜在的风险。文章提供了其他替代方案,包括使用 encoding/binary 包和 tensorflow api for go 中的解决方案。后者通过检查两个字节的顺序来确定机器的字节顺序,从而避免了不安全的包。

问题内容

我正在编写一个小程序来使用 go 检查字节序:

var i int = 0x0100
ptr := unsafe.Pointer(&i)
if 0x01 == *(*byte)(ptr) {
    fmt.Println("Big Endian")
} else if 0x00 == *(*byte)(ptr) {
    fmt.Println("Little Endian")
} else {
    // ...
}

import "unsafe" 包将 *int 转换为 *byte。 但正如 https://golang.org/pkg/unsafe/ 中提到的:

unsafe 包包含绕过 go 程序类型安全的操作。 导入不安全的包可能是不可移植的,并且不受 go 1 兼容性指南的保护。

是否有更好的方法来确定字节顺序,或者我是否必须使用不安全的包?


解决方案


您想要做的是特定于体系结构的事情,据我所知,go 并没有做太多事情来帮助您确定主机的字节顺序。使用不安全指针的解决方案可能是您能做的最好的解决方案。

如果您知道要说话的字节顺序并相应地进行编码/解码,则可以使用 encoding/binary 包:https://godoc.org/encoding/binary#ByteOrder

如果您确实需要依赖主机字节顺序,那么您可能会陷入一种应该尽量避免的设计反模式:https://commandcenter.blogspot.com/2012/04/byte-order-fallacy.html

这里还有关于这个话题的 golang-nuts 的热烈讨论,辩论双方都发表了意见:https://groups.google.com/forum/#!topic/golang-nuts/3GEzwKfRRQw

该电子邮件线程有 russ cox 的建议,即使用构建约束静态定义所需的字节顺序(或主机字节顺序):

几个月来我们的代码已经:

var hbo = binary.littleendian // hack - 我们想要主机字节顺序!

这样我们就可以使用encoding.binary来读取内容。

将其放入名为 byteorder_amd64.go 的文件中并 它不再是一个黑客。它不需要在标准中 图书馆。

希望有所帮助...

尽管仍然依赖 unsafe 包,但 google 的 tensorflow api for go 有一个很好的解决方案(请参阅 tensor.go)来测试机器的字节顺序:

var nativeEndian binary.ByteOrder

func init() {
    buf := [2]byte{}
    *(*uint16)(unsafe.Pointer(&buf[0])) = uint16(0xABCD)

    switch buf {
    case [2]byte{0xCD, 0xAB}:
        nativeEndian = binary.LittleEndian
    case [2]byte{0xAB, 0xCD}:
        nativeEndian = binary.BigEndian
    default:
        panic("Could not determine native endianness.")
    }
}

今天关于《更有效的 Go 中检查字节序的方法》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>