gpt4 book ai didi

c++ - 我自己的模板类中的 vector std::out_of_range(指向列表节点的指针的 vector ),但我不明白为什么

转载 作者:行者123 更新时间:2023-11-28 07:41:56 24 4
gpt4 key购买 nike

我正在为带有链表和指向链表中某些节点的指针 vector 的模板类编写代码。代码很难看,因为我只是写了我认为可能有效的代码,并重点修复了错误消息。

列表(相应地, vector 也是)保持排序,因为它每次插入项目时都会使用位置方法找到正确的位置。

最初,我有很多错误,经过大量尝试后我能够修复它们。现在它编译了,但是当我用 main 方法测试它时,如果这个模板类工作正常,它会抛出一条错误消息:

在抛出“std::out_of_range”实例后调用终止

什么(): vector::_M_range_check

中止(核心转储)

我知道 std::out_of_range 是什么,但我真的不明白为什么会出现这个错误。我的代码中甚至没有很多部分访问 vector 的元素。

下面是测试main方法的代码,接下来是我的模板类(和嵌套迭代器类)的定义。

#include <iostream>
#include <fstream>
#include <cstdlib>
#include <string>
#include <vector>
#include "ValliHN.h"
using namespace std;

int main() {
Valli<string> valli;

valli.insert("K");
valli.insert("H");
valli.insert("N");
valli.insert("H");
valli.insert("J");

for (Valli<string>::iterator i = valli.begin(); i != valli.end(); i++)
cout << *i << endl;

return 0;
}

模板类

#include"DList.h"
#include<iostream>
#include<vector>
#include<algorithm>
#include<cstdlib>

using std::cout;
using std::endl;
using std::cerr;
using std::vector;

template<typename I>
class Valli {

vector< DNode<I>* > va;
DList<I> lli;
size_t ratio;
friend class iterator;
friend class DList<I>;

public:

class iterator {

typename DList<I>::iterator list_iter;
iterator(DNode<I>* node)
: list_iter(typename DList<I>::iterator(node)) { }
friend class Valli<I>;
friend class DList<I>;

public:
I& operator*() const {
return *list_iter;
}

iterator& operator++() {
++list_iter;
return *this;
}

iterator operator++(int) {
iterator* ret = this;
++list_iter;
return *ret;
}

iterator& operator--() {
--list_iter;
return *this;
}

iterator operator--(int) {
typename DList<I>::iterator ret = list_iter;
--list_iter;
return ret;
}

bool operator==(const iterator& rhs) const {
return list_iter == rhs.list_iter;
}

bool operator!=(const iterator& rhs) const {
return list_iter != rhs.list_iter;
}

DNode<I>* returnCurr() const {
return list_iter.returnCurr();
}
};

explicit Valli<I>(size_t ratio=4)
: ratio(ratio),
lli(DList<I>()),
va(vector< DNode<I>* >()) { }

// Valli<I>()
// : Valli<I>(4) { }

~Valli<I>() {
// delete[] va;
// delete lli;
}

iterator insert(const I& item) {
iterator pos = position(va, item);
lli.insert(pos.returnCurr(), item);
refresh(4);
return --pos;
}

iterator find(const I& item) const {
iterator start = iterator(va.at(binsearch(va, item)));
iterator end = iterator(va.at(binsearch(va, item)+1));
while(start != end) {
if(*start = item) {
return start;
}
else {
++start;
}
}
}
// void erase(iterator itr) {}

iterator begin() const {
lli.begin();
}

iterator end() const {
lli.end();
}

private:
int binsearch(const vector< DNode<I>* > vec, const I& item) const {
int left = 0;
int right = vec.size()-1;
while(left <= right) {
int mid = (left+right)/2;
iterator iter = iterator(vec.at(mid));
if(item < *iter) {
right = mid-1;
}
else if(item == *iter) {
return mid;
}
else {
left = mid+1;
}
}
return left;
}

iterator position(const vector< DNode<I>* > vec, const I& item) const {
iterator start = iterator(vec.at(binsearch(vec, item)));
iterator end = iterator(vec.at(binsearch(vec, item)+1));
while(start != end) {
if(*start < item) {
++start;
}
else {
return start;
}
}

}

void refresh(size_t newRatio) {
iterator iter = begin();
int count = 0;
va.clear();
while(iter!=end()) {
if(count % newRatio == 0) {
va.push_back(iter.returnCurr());
}
//push_backing the last node - to be added
iter++;
count++;
}
}

};

类 DList.h 与标准库列表类非常相似。你能看到我的代码中的问题吗?另外,从良好的编程实践和编码方向的实现方面,您能告诉我我的代码总体上是好是坏吗?

非常感谢!

最佳答案

在我看来,第一个插入的 vector 超出了范围。 insert 调用 position,它调用 binsearch。 binsearch 返回 0,因为 vector 为空,position 然后调用 vector.at(0)(和 vector.at(1))。这两个都是超出范围的错误,因为 vector 是空的。

我只是盯着代码看,所以我可能犯了错误。确实,您应该使用调试器,并准确找出问题发生的位置。

关于c++ - 我自己的模板类中的 vector std::out_of_range(指向列表节点的指针的 vector ),但我不明白为什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15676763/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com