首页 > 解决方案 > 使用指针向量的问题(带代码)C++(以及对其使用便利性的疑问)

问题描述

首先,正如您将看到的,我是 C++ 的菜鸟。我相信你可以教我一些东西。

我在使用用于习惯指针和指针向量的小示例代码时遇到问题,并且我对在我的案例中使用指针向量的便利性有疑问。

1.)使用方便:我正在编写一个小型 C++ 软件。在此软件中,用户可以通过 GUI 创建某些对象(称为模块),其中包含未定义数量的不同参数(它们可能很多)。对于性能/节省内存的动摇,我认为拥有一个指向它们的指针向量而不是在向量中分配对象本身对它的管理有好处。用户还可以删除这些对象(模块)。在这种情况下使用指针向量是否明智? 我也想过使用对它们的引用,但我看到我应该使用引用包装器。

2.)特定示例:在接下来的段落中,找到一个简单代码示例,用于练习使用指针和指针向量。

文件 NumberClass.h

#ifndef NUNMBERCLASS_H
#define NUNMBERCLASS_H

class Number{
    private:
        int n;

    public:
        Number();
        Number(int n);
        int square();
        int getNumber();
};

#endif

文件 NumberClass.cpp

#include "NumberClass.h"

Number::Number(){n=0;}
Number::Number(int m){n=m;}
int Number::square(){return (n*n);}
int Number::getNumber(){return n;}

文件 NumbersContainerClass.h

#ifndef NUMBERSCONTAINERCLASS_H
#define NUMBERSCONTAINERCLASS_H
#include <vector>
#include "NumberClass.h"

class NumbersContainer{
    private:
        std::vector<Number*> numCont;
    public:
        void numberPush_back(Number n);
        Number* getNumberByPosition(int j);
        int sizeMethod();
        int capacityMethod();
};

#endif

文件 NumbersContainerClass.cpp

#include "NumbersContainerClass.h"

void NumbersContainer::numberPush_back(Number n){numCont.push_back(&n);}
Number* NumbersContainer::getNumberByPosition(int j){
    return numCont[j];
    }
int NumbersContainer::sizeMethod(){return numCont.size();}
int NumbersContainer::capacityMethod(){return numCont.capacity();}

文件 main.cpp

#include "NumbersContainerClass.h"
#include "NumberClass.h"
#include <vector>
#include <iostream>

int main(){
    Number n1;
    Number n2(2);
    Number n3(3);
    Number n4(4);
    Number n5(5);

std::cout << n1.getNumber() << std::endl;
std::cout << "n1 Address: " << &n1 << std::endl;

std::cout << n2.getNumber() << std::endl;
std::cout << "n2 Address: " << &n2 << std::endl;

std::cout << n3.getNumber() << std::endl;
std::cout << "n3 Address: " << &n3 << std::endl;

std::cout << n4.getNumber() << std::endl;
std::cout << "n4 Address: " << &n4 << std::endl;

std::cout << n5.getNumber() << std::endl;
std::cout << "n5 Address: " << &n5 << std::endl;


    NumbersContainer container;

    std::cout << "n1 Address: " << &n1 << std::endl;
    container.numberPush_back(n1);
    int k=0; //Here I just wanted to check if something changed by pasing the parameter like this.
    std::cout << (*(container.getNumberByPosition(k))).getNumber() << std::endl;
    std::cout << container.getNumberByPosition(k)->getNumber() << std::endl;

    std::cout << "n2 Address: " << &n2 << std::endl;
    container.numberPush_back(n2);
    std::cout << (*(container.getNumberByPosition(1))).getNumber() << std::endl;
    std::cout << container.getNumberByPosition(1)->getNumber() << std::endl;

    std::cout << "n3 Address: " << &n3 << std::endl;
    container.numberPush_back(n3);
    std::cout << (*(container.getNumberByPosition(2))).getNumber() << std::endl;
    std::cout << container.getNumberByPosition(2)->getNumber() << std::endl;

    std::cout << "n4 Address: " << &n4 << std::endl;
    container.numberPush_back(n4);
    std::cout << (*(container.getNumberByPosition(3))).getNumber() << std::endl;
    std::cout << container.getNumberByPosition(3)->getNumber() << std::endl;

    std::cout << "n5 Address: " << &n5 << std::endl;
    container.numberPush_back(n5);
    std::cout << (*(container.getNumberByPosition(4))).getNumber() << std::endl;
    std::cout << container.getNumberByPosition(4)->getNumber() << std::endl;

std::cout << container.getNumberByPosition(4) << std::endl;
std::cout << container.getNumberByPosition(3) << std::endl;
std::cout << container.getNumberByPosition(2) << std::endl;
std::cout << container.getNumberByPosition(1) << std::endl;
std::cout << container.getNumberByPosition(0) << std::endl;

std::cout << container.sizeMethod() << std::endl;
std::cout << container.capacityMethod() << std::endl;

return 0;
}

输出是:

0
n1 Address: 0x7ffd73484028
2
n2 Address: 0x7ffd7348402c
3
n3 Address: 0x7ffd73484030
4
n4 Address: 0x7ffd73484034
5
n5 Address: 0x7ffd73484038
n1 Address: 0x7ffd73484028
32765
32765
n2 Address: 0x7ffd7348402c
32765
32765
n3 Address: 0x7ffd73484030
32765
32765
n4 Address: 0x7ffd73484034
32765
32765
n5 Address: 0x7ffd73484038
32765
32765
0x7ffd73483ff4
0x7ffd73483ff4
0x7ffd73483ff4
0x7ffd73483ff4
0x7ffd73483ff4
5
8

当我直接返回数字类型对象时,代码工作正常,因此“Number NumbersContainer::getNumberByPosition(int k)”。然而,当我尝试返回一个指向数字的指针 (Number* NumbersContainer::getNumberByPosition(int k)" 时,尽管显然我得到了对所需数字类型对象的引用(因为我可以使用运算符 -> 或取消引用输出指针并使用为 Number "int Number::getNumber()") 定义的函数,我得到的结果对我来说是无稽之谈。我错过了什么或我不明白?我已经玩了很长时间的代码,但我总是在这一点上结束,所以我认为我不明白一些事情。

先感谢您!任何在确切问题旁边的更正/评论/观察都非常受欢迎。

标签: c++c++11pointersvectoroperators

解决方案


一个明显的错误:

您正在此行中存储临时地址Number

void NumbersContainer::numberPush_back(Number n){numCont.push_back(&n);}

因此,在该函数返回后,地址n不再有效,因为临时的生命周期n已经结束。


推荐阅读