登录
首页 >  Golang >  Go问答

为什么我们需要一个恒定时间*单字节*比较函数?

来源:Golang技术栈

时间:2023-03-21 14:54:12 120浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《为什么我们需要一个恒定时间*单字节*比较函数?》,以下内容将会涉及到golang,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

查看 Go 标准库,有一个ConstantTimeByteEq函数,如下所示:

func ConstantTimeByteEq(x, y uint8) int {
    z := ^(x ^ y)
    z &= z >> 4
    z &= z >> 2
    z &= z >> 1

    return int(z)
}

现在,我了解需要对恒定时间 字符串 (数组等)进行比较,因为常规算法可能会在第一个不相等元素后短路。但是在这种情况下,两个固定大小的整数的常规比较不是在 CPU 级别上的恒定时间操作吗?

正确答案

不必要。而且很难说编译器在进行优化后会发出什么。对于高级“比较一个字节”,您最终可能会得到不同的机器代码。在侧通道中泄漏一点点可能会将您的加密从“基本牢不可破”更改为“希望不值得破解所需的钱”。

理论要掌握,实操不能落!以上关于《为什么我们需要一个恒定时间*单字节*比较函数?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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