【发布时间】:2016-08-23 06:24:33
【问题描述】:
我使用这段代码从 boost 中生成 UUID:
boost::uuids::random_generator gen;
boost::uuids::uuid uuidId = gen();
string randomUUID = boost::lexical_cast<std::string>(uuidId);
std::remove( randomUUID.begin(), randomUUID.end(), '-');
randomUUID = "0x" + randomUUID;
它给了我十六进制数字,例如:“0xCC5B9F6946EF4448A89EDB2042E0B084”。
我的问题是:如何将此字符串(128 位十六进制数)转换为 128 位长或 64 位长(可以丢失更高的数据)?
标准 C 环礁和 C++ std::stoll 在这种情况下没有帮助。
UUID 优先用于随机生成质量。
谢谢!
【问题讨论】:
-
使用 UUID 生成随机数是一个糟糕的主意。他们没有使用类似 mersenne twister 的类似的、正确生成的随机数的熵。帮自己一个忙,实际使用 C++ 标准库中内置的功能来生成随机数like this。同样采用 UUID 的子字符串是 plain bad idea
-
我有 Mersener Twister,就我而言,它看起来像这样:
-
我有 Mersener Twister,就我而言,它看起来像这样: auto const seed = std::random_device()();标准::mt19937 mt(种子); std::uniform_int_distribution
dist(12345678, 99999999);长l1;长l2; for (int i=0; i -
boost::uuids::random_generator 使用 Mersenne Twister。因此,没有理由期望它提供比直接使用 Mersenne Twister 更好质量的随机生成。而且,正如 Mike 所说,使用 UUID 的子字符串生成随机数似乎很奇怪。
标签: c++ boost std uuid 128-bit