传递矢量<shared_ptr <derived>&gt;期望向量的函数<shared_ptr <base>&gt; </shared_ptr <base> </shared_ptr <derived>

时间:2012-07-20 15:22:33

标签: c++ inheritance shared-ptr smart-pointers

我遇到了我使用的代码结构的问题,如下所示(简化):

class SPoint
{
public:
    SPoint(double x, double y, double z) : _x(x), _y(y), _z(z) {}

protected:
    double _x, _y, _z;
}

class Point3D : public SPoint
{
public:
    Point3D(double x, double y, double z) : SPoint(x, y, z) { // default values for U and V }

protected:
    double U, V;
}

这些点用于创建折线:

class SPolyline
{
public:
    SPolyline(const vector<shared_ptr<SPoint>>& points) { // points are cloned into _points}

protected:
    vector<shared_ptr<SPoint>> _points;
};


class Polyline3D : SPolyline
{
public :
    Polyline3D(const vector<shared_ptr<Point3D>>& points) : SPolyline(points)  // doesn't compile
};

当我尝试使用此错误编译Polyline3D时,VS2010拒绝了我

error C2664: 'SPolyline::SPolyline(const std::vector<_Ty> &)' : cannot convert parameter 1 from 'const std::vector<_Ty>' to 'const std::vector<_Ty> &'
with
[
  _Ty=std::tr1::shared_ptr<SPoint>
]
and
[
  _Ty=std::tr1::shared_ptr<Point3D>
]
and
[
  _Ty=std::tr1::shared_ptr<SPoint>
]
Reason: cannot convert from 'const std::vector<_Ty>' to 'const std::vector<_Ty>'
with
[
  _Ty=std::tr1::shared_ptr<Point3D>
]
and
[
  _Ty=std::tr1::shared_ptr<SPoint>
]
No user-defined-conversion operator available that can perform this conversion, or the operator cannot be called

vector<shared_ptr<Derived>>vector<shared_ptr<Base>>没有默认转换。 知道我需要折线中点的共享所有权,如何解决这个问题?我使用的shared_ptr是标准的,不是来自Boost。

2 个答案:

答案 0 :(得分:5)

摘要远离容器并使用迭代器。

template<typename InputIterator>
Polyline3D(InputIterator begin, IntputIterator end) : SPolyline(begin ,end) {}

可以为vector实现这样的转换,但考虑到它可以引入的微妙意外(想想隐含的转换),不要让它更好。

答案 1 :(得分:0)

你可以做的另一件事是:

class Polyline3D : public SPolyline
{
public :
    Polyline3D(const vector<shared_ptr<Point3D>>& points) : SPolyline(std::vector<shared_ptr<SPoint> >(points.begin(), points.end())){}  
};