百度出来的基本上都是使用rand()。这种基于时间的随机方法,在同时生成的多个随机值是不随机的。当然通过线程休眠,使用rand也可以实现随机,效率太低了。采用c++11的正态分布引擎改进了一下。vs2015下,是没问题的,vs2012不知道行不行。如果想了解其他分布引擎,可参考c++ primer的附录。
char* GenerateStr()
{
int nSetSize = 60;//可选字符的数量
const char CCH[] = "_0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_";
static std::default_random_engine generator;
static std::normal_distribution<double> distribution(0, nSetSize);
int nSize = 10; //生成的字符串长度
char * buff = new char[nSize + 1]{ 0 };
int nCount = 0;
while (nCount < nSize )
{
int number = (double)distribution(generator);
if (number >= 0 && number <= nSetSize)
{
buff[nCount] = CCH[number];
nCount++;
}
}
buff[nSize + 1] = '\0';
/*
///通过线程休眠,使用rand也可以实现随机,效率太低
std::this_thread::sleep_for(std::chrono::milliseconds(12));
*/
return buff;
}