指向Eigen3向量的std::列表的指针或引用
Pointer or reference to std::list of Eigen3 vector
我使用Eigen3二维矢量作为opengl绘图的二维点:
typedef Eigen::Vector2d Vec2D;
然后我有一个带有向量的std::list
,我用这种方式迭代它:
std::list<Vec2D>::const_iterator it;
for(it=points.begin(); it!=points.end(); ++it) {
Vec2D p = *it;
... // something for draw (p.x(), p.y())
}
但是通过这种方式,变量p
包含一个副本,对吗?现在我不想有不必要的副本,所以我尝试了指针:
std::list<Vec2D>::const_iterator it;
for(it=points.begin(); it!=points.end(); ++it) {
Vec2D *p = &((Vec2D)*it);
... // something for draw (p->x(), p->y())
}
我发现了奇怪的语法&它是这个答案,即使我必须使用强制转换,它也能工作(不知道为什么,但它没有以其他方式编译)。
但我想使用引用而不是指针:
std::list<Vec2D>::const_iterator it;
for(it=points.begin(); it!=points.end(); ++it) {
Vec2D &p = ???
... // something for draw (p->x(), p->y())
}
但我遇到了一些编译错误,比如
invalid initialization of non-const reference of type 'Vec2D&' from a temporary of type 'Vec2D'
或者其他我无法理解的事情。。
您实际上并没有向我们展示您的尝试。从错误信息判断,看起来你做了
Vec2D &p = ((Vec2D)*it);
类型转换(Vec2D)
去除表达式*it
的引用性。在官方术语中,它变成了一个右值。
解决方案很简单。
Vec2D &p = *it; // no cast.
一个非常常量引用必须绑定到一个左值,这个左值可以出现在=
的左侧,因为引用可以这样使用。但是
(Vec2D) *it = ...; // Can't assign the result of a cast expression.
为了完整起见,C++确实允许将强制转换的结果分配给引用类型。
(Vec2D &) *it = ...; // Cast to ref type produces an lvalue.
相关文章:
- 如何使用基类指针引用派生类成员
- 将常量指针引用绑定到非常量指针
- 如果非动态变量被指针引用,何时超出范围?
- 转换指针引用的字符串
- 指针引用的生存期(以 C++为单位)
- 从 unique_ptr::get 发送指针作为指针引用进入函数
- 指针/引用的 CLion 格式
- 使用模板专用化来比较指针引用
- 如何保存指向抽象基类的指针/引用,但在 c++ 中仍然可以复制
- C++初始化指针/引用/复制细微差别
- 用数组或指针引用函数?
- 指针范围问题和返回类中封装的指针向量内的指针引用
- 强制转换为指针引用是否会导致未定义的行为
- 访问由 void 指针引用的结构的成员
- C 为什么当先前的步骤引发异常时,std :: shared_ptr的指针引用会被破坏
- 动态指针引用数组由三元运算符返回值,但有异常
- 悬空指向 int 和 char* 常量的指针/引用
- C++ 二维数组和指针引用
- 通过使用指针/引用,在C++中使用向量加快计算速度
- C++非类型模板模板到函数指针/引用