在C中随机化一个字符串

我试图在C中生成一个80个字符的固定字符串的随机排列。令我沮丧的是,我正在研究的系统缺乏strfry()。 对我来说,生成此字符串的随机排列的最佳方法是什么? 因为这将循环约。 100,000次,性能是一个问题。

只需使用Google Code中的开源GLIBC实施。

char * strfry (char *string) { static int init; static struct random_data rdata; size_t len, i; if (!init) { static int state[8] = { 1, 2, 3, 4, 5, 6, 7, 8 }; rdata.state = NULL; __initstate_r (time ((time_t *) NULL), state, 8, &rdata); init = 1; } len = strlen (string); for (i = 0; i < len; ++i) { int32_t j; char c; __random_r (&rdata, &j); j %= len; c = string[i]; string[i] = string[j]; string[j] = c; } return string; } 

您可能希望将GLIBC特定数据类型更改为更通用的数据类型。

这段代码使用了Fisher-Yates shuffle ,它实际上非常容易实现,而且效率很高。

创建一个80行数组,将一个字符和一个随机数放入数组的每一行,然后在随机数上对数组进行排序。

从排序数组中重建字符串。

void gcry_randomize(unsigned char * buffer,size_t length,enum gcry_random_level level)

使用由级别定义的随机质量填充具有长度随机字节的缓冲区。

http://www.g10code.com/p-libgcrypt.html