STM32芯片下产生伪随机数
来源:互联网 发布:linux 阻塞 毫秒 编辑:程序博客网 时间:2024/05/06 03:51
STM32芯片下产生伪随机数:
在C语言中有函数srand和rand()配合使用产生伪随机数序列。rand函数在产生随机数前,需要系统提供的生成伪随机数序列的种子,rand根据这个种子的值产生一系列随机数。如果系统提供的种子没有变化,每次调用rand函数生成的伪随机数序列都是一样的。srand(unsigned seed)通过参数seed改变系统提供的种子值,从而可以使得每次调用rand函数生成的伪随机数序列不同,从而实现真正意义上的“随机”。通常可以利用系统时间来改变系统的种子值,即srand(time(NULL)),可以为rand函数提供不同的种子值,进而产生不同的随机数序列。(这段话摘自百度百科:http://baike.baidu.com/link?url=So8XfdpHjalvYjTBdV8QqKvwv_Dss2blYbz2yzQBlIFx3DbGPQwW3bl7hVi-Ew5hsSDQT-zDWlQTpxaLagjeSK)
对于上面一段话中所提到的"种子"一次,根据自己理解注明一下,这里的“种子”的意思是要给rand()函数生成随机数时给一个启动可参考的值。
srand()函数:
头文件:#include<stdlib.h>
原型:void srand(unsigned int seed);
rand()函数:
头文件:#include<time.h>
例子参见srand()函数百度百科。
开始使用的生成种子为这样:srand((unsigned)time(NULL));这样:srand( unsigned( time(0) ) );都不行,后来根据这样的srand(seed);意思是说srand函数里面的seed值是提供种子的,若是每次这个seed值是一样的,那么每次生成的随机数也当然是一样的,在STM32中,最好采用配置1ms或者1s的Systick中断去进行计数,然后将每次的计数值传给seed,这样每次生成的随机数就会不一样。
重点做到seed在每次生成随机数的时候值不一样,rand()函数就能每次产生不同的随机数。
举个例子:
srand(gSystickMsecCount); //gSystickMsecCount这个值是在Systick中断中计数的变量
for(i=0;i<7;i++){
number[i] = rand() % 100; //生成0—100内的随机整数
}
- STM32芯片下产生伪随机数
- STM32F103产生伪随机数
- STM32 产生随机数
- 循环中产生伪随机数
- 循环中产生伪随机数
- 关于VC产生伪随机数
- BASE64的伪随机数产生
- 循环中产生伪随机数
- 常见的伪随机数产生
- linux下产生随机数
- C++各种产生伪随机数的问题
- 游戏中伪随机数的产生
- rand和srand产生伪随机数总结
- 伪随机数产生原理及用法
- 用rand()和srand()产生伪随机数
- c#循环中产生伪随机数
- 产生伪随机数的魔术公式--源码
- FPGA产生基于LFSR的伪随机数
- RFS(六)Open Browser后,页面显示This is the initial start page for the WebDriver server.的解决办法
- svn报错:could not read response body connection was closed by server
- 游戏服务器压力测试
- liunx restart和reload的区别
- C# 5.0 aynsc 和 await ,Trace改进
- STM32芯片下产生伪随机数
- App版本更新时对SQLite数据库升级或者降级遇到的问题
- iOS数据持久化存储
- LDA基本介绍以及LDA源码分析(BLEI)
- Overlay 网络
- 减少mysql主从数据同步延迟问题的详解
- Swift 闭包的使用(尾随闭包)
- linux 系统snmp安装
- Netty学习之路(1)