在CodeBlocks中对此进行编码,此程序不断出现seg错误。有人可以帮忙吗?
#include <string>
#include <iostream>
#include <sstream>
#include "include/hugeint.h"
using namespace std;
int main(int argc, char *argv[])
{
HugeInt h("123");
return 0;
}
我的HugeInt类(相关的是什么),将非常大的整数存储为整数数组
class HugeInt
{
public:
HugeInt(string);
private:
DynArray dyn;
//HugeInt& reverse();
int size;
};
HugeInt::HugeInt(string input)
{
string digits = input;
for(unsigned int i = 0; i < digits.length(); i++){
dyn.add(digits.at(i) - 48);
}
size = dyn.size();
}
我的动态数组整数类
class DynArray
{
public:
DynArray();
~DynArray();
private:
int length;
int *arr; //points to this array
int nextIndex;
};
DynArray::DynArray() {
arr = new int[10];
for (int i = 0; i < 10; i++)
arr[i] = 0;
length = 10;
nextIndex = 0; }
DynArray::~DynArray()
{
delete [] arr;
}
int DynArray::size(){
return nextIndex;
}
void DynArray::add(int val) {
int *newArr;
if (nextIndex == length) {
length = length + 10;
newArr = new int[length];
for (int i = 0; i < nextIndex; i++)
newArr[i] = arr[i];
for (int j = nextIndex; j < length; j++)
newArr[j] = 0;
delete [] arr;
arr = newArr;
}
arr[nextIndex++] = val;
}
编辑:我评论删除[] arr; out,它仍然是错误的:/
Edit2:好的,如果main如下,则代码可以正常工作。有人可以解释为什么吗?
#include <string>
#include <iostream>
#include <sstream>
#include "include/hugeint.h"
using namespace std;
int main(int argc, char *argv[])
{
string in = "1234";
HugeInt h(in);
return 0;
}
答案 0 :(得分:0)
在开始使用DynArray add()方法之前,可能需要在HugeInt构造函数中初始化DynArray。你没有在代码中包含add方法,但是如果它完成了我想象的那样,你可能在使用它之前没有构造DynArray对象,因此是seg错误。
答案 1 :(得分:0)
您发布的代码编译并运行时没有错误。
我可以推测问题正在其他地方发生,因为DynArray
不满足rule of three。
目前,如果以任何方式复制DynArray
,该副本将保持指向同一int *arr
的相同指针。
当该副本被销毁时,所有其他副本使用的数组也是如此。