[英]Strange const_iterator behavior
我正在做一个main.cpp来测试我的稀疏矩阵的实现,在那里我创建了两个const_iterator:
SparseMatrix<double>::const_iterator a,b;
a=mata.begin(); //mata previously created as SparseMatrix<double>
b=mata.end();
... //code goes on
问题是它不会调用begin和end(它甚至不会执行初始cout),但是如果我创建两个迭代器就可以了。 以下是我为const_iterators实现begin和end的方法。
const_iterator begin() const
{
cout<<"Begin"<<endl;
int minr=minRow();
int minc=minCol(findRow(minr));
mcol * mc=findCol(findRow(minr),minc);
const_iterator x;
if(mc!=NULL)
{
T* dato=&(mc->data);
x= const_iterator(genElement(minr,minc,dato));
}
else
{
x=const_iterator(NULL);
}
x.setSM(const_cast<SparseMatrix<T>*>(this));
return x;
}
const_iterator end() const
{
cout<<"End"<<endl;
const_iterator x= const_iterator(NULL);
x.setSM(const_cast<SparseMatrix<T>*>(this));
return x;
}
我注意到一个奇怪的事情是,如果我在SparseMatrix的类方法中创建了两个const_iterator,它们就能工作。
正如你所说,“ mata
[ sic ]之前创建为SparseMatrix<double>
”,但你显示的begin
和end
都标记为const
。 对于要调用的const
成员函数,对象meta
必须是const
,否则将调用begin
和end
的非const
版本。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.