周末的深夜,Linux老大发布了紧急会议通知,召集CPU、内存、硬盘等所有硬件,以及git、 vim、浏览器、c、 Java等所有软件参会。

老大对深夜打扰大家深表歉意,表示春节快来了,到时候一定让大家好好休息,然后就进入中心议题:人类要求我们学会“掷骰子”,该怎么办?

内存表示不解:为啥?想让我们赌钱玩吗?我们这儿可没有骰子!

Linux老大:其实不是真正的掷骰子,是生成随机数,随机数在我们计算机里用途极为广泛,生成密钥,进行通信,生成盐(salt)...... 不可能指望人去手工操作。

vim笑道:生成随机数? 这太简单了,让新手退出我vim就行了。

Linux老大:为啥?

vim:  哈哈,因为新手不知道怎么才能退出vim,就会瞎胡乱按一通, 非常随机,这不就形成随机数了吗?!

CPU阿甘:这笑话够冷的!

(还不认识CPU阿甘的同学,可以移步《CPU阿甘》)

Linux老大:口头警告vim一次,严肃点儿, 生成随机数是非常重要的事情,人类要求:

1.  要杂乱无章

2.  不能预测,不能根据已经生成的随机数,推测出下一个随机数是啥

3.  不能重现, 无法重现和某一随机数列完全相同的数列

听到此处,大家都吸了一口冷气,这要求够高的!人类通过掷骰子可以达到这个要求,但是计算机里都是确定的算法和程序,这该怎么办?

C老头儿说:我提一个方案,我听说人类有个算法,叫做什么线性同余算法,似乎可以生成随机数。

C老头儿写下了一个公式:

内存想起和CPU阿甘折腾过的递归函数调用,说到:“看到递归我就头晕。”

C老头说:这个算法很简单,A, C, M 都是精心挑选的整数,使用者在生成随机数之前,先选一个种子(seed),比如说用当前的时间戳当作种子,我们用简单的数字做个实验, 让A = 11 , C =5, M = 13,  seed = 15

“看看,是不是挺随机的!”   C老头儿挺得意。

Java 说:“这个算法很简单嘛,效果也不错,我也实现一下,放到我的java.util.Random当中吧。”

C老头说:“我就放到我的srand函数和rand函数里。srand用来设定‘种子’,rand用来获取下一个随机数。”

srand((unsigned) time(&t));
// 输出5个随机数
for(int i=1 ;i<=5; i++){printf("%d\n", rand());
}

Java说:“看看,还是面向对象好吧,我的Random类封装了内部状态,用户只需要在创建Random对象的时候把种子传进去(不传也行,我自己默认给它设置一个),然后就nextInt()方法就可以了。多简单!”

Random r = new Random();
for(int i=1; i<=5; i++){System.out.println(r.nextInt());
}

C老头儿正要反击自以为是的Java, CPU阿甘又发言了:“不对啊,你这个随机数不符合我们老大的要求啊,这不是真正的随机数,这是伪随机数!

C老头儿马上把注意力转移到阿甘身上:“凭什么说这是伪随机数?”

CPU阿甘说:“老大说了,要不可预测,但是你这公式,我如果知道了上一个随机数,下一个随机数我自己代入那个公式就可以计算出来了,在我这里,一毫秒都用不了,完全可以预测。”

阿甘此言不虚,他的速度是整个计算机系统最快的。

"还有,你居然用当前时间做种子,那我也用同样的时间做种子,岂不是可以生成和你一模一样的随机数队列?完全可以重现啊。”

C老头儿连续挨了两记闷棍,嘴里嘟囔着,但也说不出话来了。

Linux老大赶紧和稀泥:“虽然是伪随机数,但是这个算法非常简单,对于那些对安全要求不高的场合,比如玩游戏的时候,还是非常有用的。我们再想想,怎么生成真正的随机数吧!”

C老头儿说到:要不这样,我们可以使用Hash函数。

R1 = hash(seed)

seed = seed + 1

R2 = hash(seed)

seed = seed + 1

R3 = hash(seed)

seed = seed + 1

R4 = hash(seed)

......

CPU阿甘说:“这个方法还行,在不知道种子(seed)的情况下,你给我一个随机数,我是无法预测下一个的,因为随机数是hash函数生成的,是个单向的过程。但是,如果我知道了种子,那就可以生成和你一模一样的随机数列,所以不满足‘不可重现’的性质。”

看来生成真正的随机数太难了,大家都沉默了。

过了良久, vim突然说到:你们以为我说的是笑话,但是思路却是可以借鉴啊?大家想想

用户敲击键盘的速度节奏是不是随机的? 

用户的鼠标移动是不是随机的? 

网卡每秒发送的数据量是不是随机的? 

硬盘每秒写入的数据是不是随机的? 

如果我们把这些随机的东西给综合起来......

Linux老大非常高兴:“没错,我们可以把它们认为是机器运行的环境噪音,我把它们收集起来放到一个池子里......”

CPU阿甘马上接口:“然后,可以用个Hash算法对这个池子中的内容做个消息摘要,结果就是真随机数了!杂乱无章,无法预测,无法重现。”

vim感觉有点不爽,这俩人也太会抢功劳了。

C老头儿也频频点头:“这个办法妙啊,我可以修改一下我的rand函数,来获得这个值......”

Linux老大:“别别,你的伪随机数还是要保留,上周码农翻身公众号刚刚说过,一切皆文件,我可以生成一个特殊的文件,就叫/dev/random吧,这样程序员就可以使用最常用的open ,read等方法来调用了!”

Linux老大说完,又感慨了一句:“终于,我们学会掷骰子了!”

一天以后。

CPU阿甘兴冲冲地跑来找Linux老大:老大,昨天忘了一件事,我的硬件就支持真正的随机数生成啊,我可以利用电阻的热噪声来生成的,是真随机数,用RdRand指令就能获得。

Linux老大:这个硬件是你出生的时候就被植入了,是个黑盒子,如果NSA在里边安装了后门,怎么办?

CPU阿甘看着自己的身体,愣住了......

计算机:上帝不掷骰子,人类居然让我们掷骰子?相关推荐

  1. 为什么计算机模拟不了人脑,为什么计算机永远不会拥有人类的意识?听完科学家的解释恍然大悟...

    原标题:为什么计算机永远不会拥有人类的意识?听完科学家的解释恍然大悟 人类是现在地球的霸主,是智慧生命.地球在6500万年前也有一类霸主生物,它们就是恐龙.可是恐龙尽管称霸地球1.6亿年的岁月,但是它 ...

  2. 语言编程思维陈萌_这本书告诉你,计算机为何能读懂人类语言,编程思维让你更聪明...

    在这个互联网时代,我们出门购物.拍照.打电话.浏览信息,只需要带上一部智能手机就可以了.如果在20年前,要实现这些功能,需要带一大堆东西.如今,我们口袋里的这台计算机,和50年前送宇航员上月球的那台计 ...

  3. 投掷骰子的python代码_模拟骰子(Python),掷骰子

    模拟掷骰子实际是抽取(1~6之间的)随机数问题,涉及random模块,后面版本的数据可视化主要应用matplotlib.pyplot模块. 1.0:模拟一个骰子的结果.首先定义roll_dice()函 ...

  4. Cell期刊论文:为什么计算机人脸识别注定超越人类?(祖母论与还原论之争)...

    终于找到ML日报的微信链接,抄之...................................... 请拜访原文链接:[祖母论与还原论之争]为什么计算机人脸识别注定超越人类? 评价:      ...

  5. 人工智能对学计算机的影响,计算机专业大学生对人工智能对人类的影响分析.docx...

    计算机专业大学生对人工智能对人类的影响分析 人工智能对人类生活的影响 -- 兰红勇信号1501 随着计算机技术的快速发展和广泛应用,人工智能的思想和技术对人类的影响与日俱增,人工智能的发展将会对人类社 ...

  6. 计算机无法超过人类智慧,计算机的智力会超过人类吗?

    计算机的智力会超过人类吗? 1997年,世界象棋冠军卡斯帕罗夫同超级计算机"深蓝"进行了一次六局棋的复赛.在之前的1996年,卡斯帕罗夫以三胜二和一负的成绩胜了"深蓝&q ...

  7. 编写程序模拟掷骰子游戏。已知掷骰子游戏的游戏规则为:每个骰子有6面,这些面包含1、2、3、4、5、6个点,掷两枚骰子之后,计算点数之和。

    编写程序模拟掷骰子游戏.已知掷骰子游戏的游戏规则为:每个骰子有6面,这些面包含1.2.3.4.5.6个点,掷两枚骰子之后,计算点数之和.如果第一次掷的点数和为7或11,则游戏者获胜:如果第一次掷的点数 ...

  8. 未来的工作都被计算机代替,未来计算机或机器人会替代人类的工作吗?为什么?_科技数码通...

    会有部分重复性的工作被机器人所替代. 随着科技的发展,人类社会中大部分的中低层的重复性工作的岗位会将被人工智能与机器人所取代.这是科技发展所无法避免的趋势. 未来计算器或机器人无法完全替代人的全部工作 ...

  9. python掷骰子实验报告_python-模拟掷骰子,两个筛子数据可视化

    """ 作者:zxj 功能:模拟掷骰子,两个筛子数据可视化 版本:3.0 日期:19/3/24 """ import random impo ...

最新文章

  1. Django error信息邮件通知功能配置部署
  2. HBase Shell常用的命令
  3. 实用python技巧
  4. emacs python debug_我常用的 Python 调试工具 - 博客 - 伯乐在线
  5. 不提拔你,就是因为你只想把工作做好
  6. 40 个重要的 HTML5 面试问题及答案
  7. C++ 中vector的嵌套使用
  8. Linux开发标准LSB简介:Linux Standard Base
  9. 3.从尾到头打印链表
  10. 如何复制百度文库、豆丁网上的文本
  11. GAMBIT FLUENT 简要介绍
  12. java word在线编辑_[原创]Java开发在线打开编辑保存Word文件(支持多浏览器)
  13. .dat文件三维点云可视化
  14. jar 加入本地maven仓库
  15. 基础用户登录测试用例-最全用例设计
  16. PythonOperator、BashOperator以及Xcom使用
  17. 尝试导出Cities Skyline完整城市模型遇到的问题与解决
  18. 《Android 应用 之路》一个类似今日头条的APP
  19. Win11任务栏大小调整
  20. 进出口海运货物保险条款及做法

热门文章

  1. 【报告分享】2021三八节美妆行业营销报告-WEIQ(附下载)
  2. 最新!有了这个WIZNET选型指南,再也不迷茫了(一)
  3. nginx 限流学习
  4. 论文笔记-VulDeeLocator: A Deep Learning-based Fine-grained Vulnerability Detector
  5. 初中学历怎么提高学历 有哪些途径
  6. 看中国 | 淘宝总裁蒋凡:当前有两件事情真正推动零售业发展
  7. 红头文件也用“码农”,郑州3年培养10W“码农”
  8. 漂亮的水晶图标制作方法
  9. 【JS】单感叹号 和 双感叹号 的用法
  10. 基于SIP协议的IP电话增值业务实现技术