我想从Openssl制作随机数。
所以。我制作了程序:
#include "openssl/rand.h"
struct randomData
{
char str[32];
}
int main()
{
std::vector<randomData> vecStr;
randomData rd;
vecStr.emplace_back(rd);
RAND_bytes((unsigned char *)vecStr[i].str, sizeof(vecStr[i].str));
std::string ss = to_hex(vecStr[i].str, sizeof(vecStr[i].str));
std::cout << "Random Nonce Hex Data : " << ss << " // Key Length : " << ss.length()<<std::endl;
return 0;
}
// [out put]
// Random Nonce Hex Data : f0f5e38e596fdb2f7cef79d3706fcbf111decaa844154295b89b90eb65925a53 // Key Length : 64
但是我不想构造。只需使用 vector 。 所以,我尝试了。
std::vector<char> str;
str.reserve(33);
RAND_bytes((unsigned char *)&str, sizeof(str));
std::string ss = to_hex((char*)&str, sizeof(str));
std::cout << "Random Nonce Hex Data : " << ss << " // Key Length : " << ss.length() << std::endl;
// [ output ]
// Random Nonce Hex Data : f1935de540b5a75bcaa9eab4b173abcb6a840bf83c4181ee // Key Length : 48
// Segmentation fault (core dumped)
您可以看到错误日志。 我搜索了“保留”与“调整大小”的区别。但是那些功能引起了同样的错误。
为什么会这样?
答案 0 :(得分:5)
首先,它应该是resize
,而不是reserve
。
第二,使用.data()
而不是强制转换为指针类型。
第三,它是str.size()
,而不是sizeof(str)
。
std::vector<char> str(33);
RAND_bytes(reinterpret_cast<unsigned char*>(str.data()), str.size());
std::string ss = to_hex(str.data(), str.size());