很长一段时间我没有使用c ++而且我有一些基本的错误。你能告诉我为什么我的通用代码会出现Segmentation Fault吗? 当我使用int作为数组类型时,它工作得很好但是当我用“Trapdoor”类型更改它时,它会给我Seg Fault。
array<array<int, colN>, rowN> SmartIds::createMatrix() {
array<array<int, colN> , rowN> a;
for(int i = 0; i < rowN; i++) {
a[i] = createTrapdoors();
}
//sort(a.begin(), a.end());
return a;
}
以下代码生成seg fault
array<array<Trapdoor, colN>, rowN> SmartIds::createMatrix() {
array<array<Trapdoor, colN> , rowN> a;
for(int i = 0; i < rowN; i++) {
a[i] = createTrapdoors();
}
//sort(a.begin(), a.end());
return a;
}
我将我的功能称为如下;
auto i = createMatrix();
Trapdoor.cpp类
#include "Trapdoor.h"
#include <cryptopp/pwdbased.h>
using namespace std;
Trapdoor::Trapdoor() {
// TODO Auto-generated constructor stub
key = nullptr;
seed = nullptr;
iv = nullptr;
counter = 0;
}
Trapdoor::Trapdoor(byte* keyy, byte* ivv) {
key = keyy;
seed = keyy;
iv = ivv;
counter = 0;
}
Trapdoor::~Trapdoor() {
// TODO Auto-generated destructor stub
delete iv;
delete key;
delete seed;
}
void Trapdoor::deriveKeywithCounter() {
SecByteBlock derived(32);
PKCS5_PBKDF2_HMAC<SHA1> kdf;
//kdf.DeriveKey(derived.data(), derived.size(), 0, (byte*)b->data(), sizeof(b), NULL, 0, 100);
memset(iv, 0x00, CryptoPP::AES::DEFAULT_KEYLENGTH);
counter++;
}
int Trapdoor::getCounter() {
return counter;
}
答案 0 :(得分:1)
Trapdoor
类没有正确的复制构造函数或复制赋值运算符。因此,当按值复制对象时,旧的和新的都会调用析构函数,指针会被释放两次等等。
很少有好的设计可以让你的班级在delete
的事情上调用new
。您的代码需要明确谁负责释放内存。
通常,最好的解决方案是编码Trapdoor
,以便它实际上根本不需要任何delete
;那么你不必编写任何特殊功能。见Rule of three/five/zero。 (如果您显示类定义,我将更新此帖子以包含代码示例。)