
我遇到的问题是,当我尝试打印其内容时,只有数组中的第一项保持适当的值(其余的似乎是随机位模式).
这是返回功能:
Qline* linesData::getList(){ Qline *lineList2[50]; for(int i = 0; i < 50; i++){ lineList2[i] = new Qline(10,10 * i,100,100); }return *lineList2;} 以下是尝试使用它的函数:
voID runtimeWindow::drawAlllines(){ Qline* lines = linesData.getList(); for(int i = 0; i < 5; i++){ qDeBUG() << lines[i].x1(); }}解决方法 使用std :: vector和std:shared_ptr,如下所示: std::vector<std::shared_ptr<Qline> > linesData::getList(){ std::vector<std::shared_ptr<Qline> > lineList2; for(int i = 0; i < 50; ++i){ lineList2.push_back(new Qline(10,10*i,100)); } return lineList2;} 和
voID runtimeWindow::drawAlllines(){ std::vector<std::shared_ptr<Qline> > lines = linesData.getList(); for(auto i = lines.begin(); i != lines.end(); ++i){ qDeBUG() << (*i)->x1(); }} 如果您的编译器中没有std :: shared_ptr,请使用boost版本.
使用std :: vector容器避免了与C样式相关的问题(例如缓冲区溢出),并且std :: shared_ptr在完成向量内容时执行一种垃圾收集,以帮助防止内存泄漏.
您也可以通过执行以下 *** 作完成此 *** 作而不需要指针:
std::vector<Qline> linesData::getList(){ std::vector<Qline> lineList2(50); for(int i = 0; i < 50; ++i){ lineList2[i].setline(10,100); } return lineList2;} 然后使用它们绘制它们
voID runtimeWindow::drawAlllines(){ std::vector<Qline> lines = linesData.getList(); for(auto i = lines.begin(); i != lines.end(); ++i){ qDeBUG() << i->x1(); }} 总结 以上是内存溢出为你收集整理的在C中,我想从函数返回一个对象数组,并在另一个函数中使用它全部内容,希望文章能够帮你解决在C中,我想从函数返回一个对象数组,并在另一个函数中使用它所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)