60人参与 • 2025-03-17 • C/C++
<stdlib.h>
或 <cstdlib>
#include <stdlib.h> #include <time.h> int main() { srand(time(null)); // 初始化随机数生成器 int random_number = rand() % 100; // 生成 0 到 99 之间的随机数 printf("random number: %d\n", random_number); return 0; }
<random>
#include <random> #include <iostream> int main() { std::random_device rd; // 真随机数生成器 std::mt19937 gen(rd()); // mersenne twister 引擎 std::uniform_int_distribution<> dis(0, 99); // 生成 0 到 99 之间的整数 int random_number = dis(gen); std::cout << "random number: " << random_number << std::endl; return 0; }
#include <stdio.h> #include <stdlib.h> int main() { file *file = fopen("/dev/urandom", "rb"); unsigned char random_byte; if (fread(&random_byte, 1, 1, file) != 1) { perror("fread"); exit(exit_failure); } fclose(file); int random_number = random_byte % 100; printf("random number: %d\n", random_number); return 0; }
<x86intrin.h>
#include <x86intrin.h> #include <stdio.h> int main() { unsigned int random_number; _rdrand32_step(&random_number); // 可能需要多次尝试才能成功 printf("random number: %u\n", random_number % 100); return 0; }
<openssl/rand.h>
#include <openssl/rand.h> #include <stdio.h> int main() { unsigned char random_bytes[4]; // 生成 4 字节随机数 if (!rand_bytes(random_bytes, sizeof(random_bytes))) { printf("rand_bytes failed\n"); return 1; } unsigned int random_number = *(unsigned int *)random_bytes; printf("random number: %u\n", random_number % 100); return 0; }
rand()
, <random>
): 适用于对随机性要求不高的场合,如游戏开发中的简单随机事件。/dev/urandom
, openssl, 硬件随机数生成器): 适用于安全性要求高的场合,如密码学应用、加密密钥生成。/dev/random
时要注意,如果系统熵池中的熵不够,读取 /dev/random
可能会阻塞,直到有足够的熵产生。rand()
和 srand()
,因为它们生成的是伪随机数,不适合用于加密。这些方法覆盖了从简单的伪随机数到高质量的真随机数生成的不同场景。
到此这篇关于c/c++随机数生成的五种方法的文章就介绍到这了,更多相关c/c++随机数生成内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论