我一直在努力,我似乎无法正常工作。我正在返回一个指针列表的最后一个值,我想打印它,但它打印一个非常随机的数字。我假设这是指针的内存地址,但是当我取消引用它时,我的输出仍然做同样的事情。
我的指针列表是一个指针列表,例如:list<int*> pointerList
例如,这是我的方法返回:
int* end() { return (pointerList.back()); }
这就是我所说的。
int* totry = ca.end();
cout << *totry;
这是打印内存地址而不是值。有没有人有任何想法如何解决这个问题?
提前致谢!
编辑:
这是int指针指向的内容:
我有一个值列表,例如[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
我有一个指针列表,指向该列表的不同部分,如下所示:
[0,4,8,12]
我的Header文件中有代码:int* end() { return (pointerList.back()); }
,以及.cpp文件中的调用:
int * totry = ca.end(); cout&lt;&lt; * totry;
这是我声明我的指针列表
的方式 class ptrList
{
public:
std::list<value_type> listOfValues;
std::list<*int> pointerlist;
我在“添加”功能中填充我的列表指针,我这样做:
int lstsqrt = 4;
for (int a = 1; a < lstsqrt; a++)
{
int endptr = a + (int)lstsqrt;
pointerlist.push_back((&*listOfValues.begin() + endptr)); //( (lstsqrt - 1) + a) );
}
这是我的end()方法
int* end() {return (pointerlist.back());}
然后将其传递给我的toTry Variable。
答案 0 :(得分:6)
这一行可能存在一个问题:
pointerlist.push_back((&*listOfValues.begin() + endptr));
您的listOfValues
是std::list
,因此其值不会存储在连续的内存块中。所以你得到一个带有listOfValues.begin()
的第一个元素的迭代器,用*
取消引用迭代器,用&
获取int*
的地址,然后添加pointerlist.push_back((&*(listOfValues.begin() + endptr)));
一些值,它指向内存,你不知道它是什么。
尝试这样做:
endptr
将+
添加到迭代器(沿列表推进),然后取消引用并获取地址。实际上,您可能需要使用advance
而不是{{1}}。