密码学中的伪随机数

本文介绍了密码学中的伪随机数概念,包括伪随机函数(PRF)和伪随机数生成器(PRNG)。PRF用于产生固定长度的伪随机位串,而PRNG则产生无限长的位流。讨论了C语言中rand()函数的工作原理和种子设置,强调了随机数的分布均匀性和独立性。文章还探讨了PRNG的两种类型,特别提到了线性同余发生器和BBS发生器,它们的安全性和基于因子分解的困难性。
摘要由CSDN通过智能技术生成

小计

1、PRF

PRF代表伪随机函数,那么伪随机函数对应的伪随机数生成器又是什么,接下来会简单介绍一下,首先需要明白,伪随机函数是怎么生成的。

- 随机数生成函数

真正意义上的随机数(或者随机事件)在某次产生过程中是按照实验过程中表现的分布概率随机产生的,其结果是不可预测的,是不可见的。而计算机中的随机函数是按照一定算法模拟产生的,其结果是确定的,是可见的。我们可以这样认为这个可预见的结果其出现的概率是100%。所以用计算机随机函数所产生的“随机数”并不随机,是伪随机数。从定义我们可以了解到,伪随机数其实是有规律的。只不过这个规律周期比较长,但还是可以预测的。主要原因就是伪随机数是计算机使用算法模拟出来的,这个过程并不涉及到物理过程,所以自然不可能具有真随机数的特性。
那么我们通常使用的随机数函数:rand()又是什么原理呢,我们来简单介绍一下。依赖于stdlib.h的伪随机数生成函数rand(),使用时主要如下所示:

#include <stdio.h>
#include <stdlib.h> 
int main (){
   
       int random = rand();
           printf("%d\n"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值