C++ - 向量中的 std::unique_ptr <> 为 nullptr

C++ - std::unique_ptr in vector<> is nullptr

本文关键字:lt gt nullptr ptr unique 向量 C++ std      更新时间:2023-10-16

我想将Particle对象存储在vector对象中,以便以后可以访问它。 这些粒子(ElectronsProtons(继承自包含toString()虚方法的Particle类。然后,在Electron类和Proton类中重写此toString()方法。

当我读取向量容器时,我想访问特定于ElectronProtontoString()方法,而不是Particle

显然,一种方法是使用std::unique_ptr.这是我尝试运行的代码部分:

int main(){
/**/
std::vector<std::unique_ptr<Particle>> particles(nbParticles);
particles.push_back(std::unique_ptr<Electron>( new Electron(1.0, 2.0, 3.0)));
particles.push_back(std::unique_ptr<Proton>(new Proton(1.0, 2.0, 3.0)));
particles.push_back(std::unique_ptr<Particle>(new Particle(0.0, 0.0, 1.0, 2.0, 3.0)));
if (particles[0]==nullptr){
std::cout<< "index=0 : nullptr"<<std::endl; //There is a null_ptr at particles[0]
}
if (particles[2]==nullptr){
std::cout<< "index=2 : nullptr"<<std::endl; //There is not a null_ptr at particles[2]
}
std::cout<<particles[0]->toString()<<std::endl; //This is what I'm trying to do
/**/
}

指向Particle对象的指针似乎没问题,但指向ElectronProton则不行。我想构造函数有问题吗?

class Particle
{
public:
Particle();
Particle(double mass, double charge, double posX, double posY, double posZ);
virtual std::string toString() const;
}
class Electron : public Particle
{
public:
Electron(double PosX, double PosY, double PosZ);
virtual std::string toString() const;
}
class Proton : public Particle
{
public:
Proton(double PosX, double PosY, double PosZ);
virtual std::string toString() const;
}

和定义:

Particle::Particle(double mass, double charge, double posX, double posY, double posZ) :
m_mass(mass), m_charge(charge),
m_posX(posX), m_posY(posY), m_posZ(posZ) {}

Electron::Electron(double PosX, double PosY, double PosZ) :
Particle(9.109E-31, -1.602E-19, PosX, PosY, PosZ){}
Proton::Proton(double PosX, double PosY, double PosZ) :
Particle(9.109E-31, +1.602E-19, PosX, PosY, PosZ){}

你犯了一个经典的错误,即使是最有经验的C++程序员也会绊倒:你用初始大小声明了向量,然后push_back了额外的元素,而不是分配给现有元素。通过从矢量初始化中删除(nbParticles)来解决此问题。