我的编程空间,编程开发者的网络收藏夹
学习永远不晚

遇到 MD5 计算整数部分的困难

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

遇到 MD5 计算整数部分的困难

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《遇到 MD5 计算整数部分的困难》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

我正在研究 md5 实现,并使用维基百科上找到的伪代码为整数正弦的二进制部分编写了以下代码。我发现我的输出与广泛可用的预先计算的表之间存在差异。

我试图弄清楚我的代码是否不正确,或者维基百科上的伪代码是否不正确。在下面的代码中将 math.floor 替换为 math.ceil 可以修复预计算表和我的输出之间的差异。

package main

import "fmt"
import "math"

func main() {
        var i float64
        for i < 64 {
                x := uint(math.floor(float64(math.maxuint32) * math.abs(math.sin(i+1))))
                fmt.printf("%d : %x\n", uint(i+1), x)
                i = i + 1
        }
}
1 : d76aa477
2 : e8c7b755
3 : 242070db
4 : c1bdceee

第 1 行和第 2 行与预先计算的表不同,而第 3 行一致。


解决方案


问题是 math.maxuint32 相差一!也就是说,232-1 而不是 232

但无论如何,最简单/最快/常见/最好的选择是使用预先计算的表。

最终的 md5 规范是 RFC 1321:

4294967296乘以abs(sin(i))的整数部分,其中i的单位是弧度。

其中“整数部分”应理解为下限函数。当然,通过 floor(abs(sin)) 的适当精度,可以给出 rfc 表中的数字。在这里,每个条目重新格式化为 8 个十六进制数字,并与 Wolfram's Alpha 吐出的 baseform[floor[abs[2^32 sin[range[64]]]],16] 进行交叉检查。

d76aa478 e8c7b756 242070db c1bdceee f57c0faf 4787c62a a8304613 fd469501 698098d8 8b44f7af ffff5bb1 895cd7be 6b901122 fd987193 a679438e 49b40821 f61e2562 c040b340 265e5a51 e9b6c7aa d62f105d 02441453 d8a1e681 e7d3fbc8 21e1cde6 c33707d6 f4d50d87 455a14ed a9e3e905 fcefa3f8 676f02d9 8d2a4c8a fffa3942 8771f681 6d9d6122 fde5380c a4beea44 4bdecfa9 f6bb4b60 bebfbc70 289b7ec6 eaa127fa d4ef3085 04881d05 d9d4d039 e6db99e5 1fa27cf8 c4ac5665 f4292244 432aff97 ab9423a7 fc93a039 655b59c3 8f0ccc92 ffeff47d 85845dd1 6fa87e4f fe2ce6e0 a3014314 4e0811a1 f7537e82 bd3af235 2ad7d2bb eb86d391

终于介绍完啦!小伙伴们,这篇关于《遇到 MD5 计算整数部分的困难》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~编程网公众号也会发布Golang相关知识,快来关注吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

遇到 MD5 计算整数部分的困难

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

遇到 MD5 计算整数部分的困难

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《遇到 MD5 计算整数部分的困难》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己
遇到 MD5 计算整数部分的困难
2024-04-04

PHP 计算商的整数部分

php 计算商的整数部分可以使用以下方法:使用 floor() 函数向下取整为最接近的整数。使用取整运算符 int 截断小数部分。PHP 计算商的整数部分在 PHP 中,可以使用浮点除法运算符 / 计算商的浮点部分。但是,如果我们只想要商
PHP 计算商的整数部分
2024-04-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录