首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么在使用构造函数后,指针的向量没有保存为类成员?

在使用构造函数后,指针的向量没有保存为类成员的原因可能有以下几点:

  1. 构造函数中没有将指针的向量保存为类成员:构造函数是用来初始化对象的特殊成员函数,它在对象创建时被调用。如果在构造函数中没有将指针的向量保存为类成员,那么在构造函数执行完毕后,指针的向量就会被销毁,无法在类的其他成员函数中访问。
  2. 指针的向量是局部变量:如果指针的向量是在构造函数中定义的局部变量,那么它的作用域仅限于构造函数内部。一旦构造函数执行完毕,局部变量就会被销毁,无法在类的其他成员函数中访问。
  3. 指针的向量没有被正确传递或赋值:如果在构造函数中创建了指针的向量,并且希望将其保存为类成员,需要将其传递给类成员或使用赋值操作符进行赋值。如果没有正确传递或赋值,指针的向量就无法保存为类成员。

为了解决这个问题,可以在类的定义中声明一个指针的向量作为类成员,并在构造函数中将其正确传递或赋值。这样,在类的其他成员函数中就可以访问和操作这个指针的向量了。

以下是一个示例代码:

代码语言:txt
复制
#include <vector>

class MyClass {
private:
    std::vector<int>* ptrVector; // 声明一个指针的向量作为类成员

public:
    MyClass(std::vector<int>* vector) {
        ptrVector = vector; // 将传递的指针的向量赋值给类成员
    }

    void printVector() {
        for (int i : *ptrVector) {
            std::cout << i << " ";
        }
        std::cout << std::endl;
    }
};

int main() {
    std::vector<int> myVector = {1, 2, 3, 4, 5};
    MyClass myClass(&myVector); // 创建类对象时传递指针的向量

    myClass.printVector(); // 输出:1 2 3 4 5

    return 0;
}

在上述示例中,通过将指针的向量作为构造函数的参数传递给类对象,并在构造函数中将其赋值给类成员,实现了在类的其他成员函数中访问和操作指针的向量的目的。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

C++运算符重载详解

C++语言的一个很有意思的特性就是除了支持函数重载外还支持运算符重载,原因就是在C++看来运算符也算是一种函数。比如一个 a + b 的加法表达式也可以用函数的形式:operator + (a, b)来表达。这里的operator +代表的就是加法函数。高级语言中的表达式和数学表达式非常相似,在一定的程度上通过运算符来描述表达式会比通过函数来描述表达式更加利于理解和阅读。一般情况下在重载某个运算符的实现时最好要和运算符本身的数学表示意义相似,当然你也可以完全实现一个和运算符本身意义无关的功能或者相反的功能(比如对某个+运算符实现为相减)。运算符函数和类的成员函数以及普通函数一样,同样可分为类运算符和普通运算符。要定义一个运算符函数总是按如下的格式来定义和申明:

03

《挑战30天C++入门极限》图例实解:C++中类的继承特性

上图是一个抽象描述的特性继承表   交通工具是一个基类(也称做父类),通常情况下所有交通工具所共同具备的特性是速度与额定载人的数量,但按照生活常规,我们来继续给交通工具来细分类的时候,我们会分别想到有汽车类和飞机类等等,汽车类和飞类同样具备速度和额定载人数量这样的特性,而这些特性是所有交通工具所共有的,那么当建立汽车类和飞机类的时候我们无需再定义基类已经有的数据成员,而只需要描述汽车类和飞机类所特有的特性即可,飞机类和汽车类的特性是由在交通工具类原有特性基础上增加而来的,那么飞机类和汽车类就是交通工具类的派生类(也称做子类)。以此类推,层层递增,这种子类获得父类特性的概念就是继承。   下面我们根据上图的理解,有如下的代码: #include <iostream> using namespace std; class Vehicle { public: void EditSC(float speed,int total); protected: float speed;//速度 int total;//最大载人量 }; void Vehicle::EditSC(float speed,int total) { Vehicle::speed = speed; Vehicle::total = total; } class Car:public Vehicle//Car类继承Vehicle的特性,Car类是Vehicle的派生类 { public: Car() { aird=0; } protected: int aird;//排量 }; class plane:public Vehicle { protected: float wingspan;//翼展 }; void main() { Car a; a.EditSC(150,4); cin.get(); }   派生类的定义可以在类名称后加冒号public空格加基类名称进行定义,如上面代码中的class Car:public Vehicle。   一旦成功定义派生类,那么派生类就可以操作基类的所有数据成员包括是受保护型的,上面代码中的a.EditSC(100,4); 就是例子,甚至我们可以在构造派生类对象的时候初始化他们,但我们是不推荐这么做的,因为类于类之间的操作是通过接口进行勾通的,为了不破坏类的这种封专装特性,即使是父类于子类的操作也应按遵循这个思想,这么做的好处也是显而易见的,当基类有错的时候,只要不涉及接口,那么基类的修改就不会影响到派生类的操作。

02
领券