Gaf*_*ffi 2 c++ loops member-variables
在获得有关这个问题的帮助后,我被引导进行更好的调试。在这个过程中,我发现我的问题是这样的:
在 C++ 中工作时,尝试将类的成员变量设置为一个值是可行的,但在循环时则不行。我已将我的代码(遵循)减少到我认为最简单的代码,因为仍然会产生错误。
调用类 Mover 的函数来修改变量 pMovXPOS,然后可以在同一范围内(在该函数内)并从调用它的位置(在循环内)检索更新后的变量。然而,在循环时,变量似乎被重置为其原始值。
我在这里发布了完整的测试代码。问题出在Main-test.cpp文件的RunWorld()函数中。如果编译并运行,您应该看到显示变量更改然后重置的输出。
这是范围问题吗?建设/破坏问题?指针/引用问题?我不知道从哪里开始(除了更好的调试)。
(由于我是 C++ 新手,我确信我使用的样式和/或方法存在一些明显的问题。如果有任何主要禁忌,请随意指出。)
预先感谢您的任何帮助!
//Main-Test.cpp
#include "Globals-Test.h"
#include "Mover-Test.h"
std::vector < Mover > AllMovers;
long SysCounter;
Mover CreateNewMover() {
Mover TempMover;
    TempMover.setXPOS(5);
    TempMover.setYPOS(10);
    return TempMover;
}
void RunWorld() {
Mover TempMover;
unsigned int iMoverLoop;
    srand ( time(NULL) );
    AllMovers.push_back(CreateNewMover());
    for (SysCounter = 0; SysCounter <= 50; SysCounter++) {
        for (iMoverLoop = 0; iMoverLoop < AllMovers.size(); iMoverLoop++) {
            std::cout << "Loop #:" << SysCounter << std::endl;
            TempMover = AllMovers.at(iMoverLoop);
            std::cout << "Is: " << TempMover.getXPOS() << std::endl;
            TempMover.DoMove();             
            std::cout << "Is: " << TempMover.getXPOS() << std::endl;
        }
    }
}
int main() {
    RunWorld();
    return 0;
}
//Globals-Test.h
#include <stdlib.h>
#include <stdio.h>
#include <iostream>
#include <sstream>
#include <unistd.h>
#include <ctype.h>
#include <math.h>
#include <string>
#include <vector>
#include <time.h>
#include <fstream>
//Mover-Test.h
extern long MoverIndex;
class Mover {
private:
    int pMovXPOS;
    int pMovYPOS;
public:
    int getXPOS();
    void setXPOS(int newXPOS);
    int getYPOS();
    void setYPOS(int newYPOS);
    Mover();
    ~Mover();
    void DoMove();
};
//Mover-Test.cpp
#include "Globals-Test.h"
#include "Mover-Test.h"
Mover::Mover() {    
}
Mover::~Mover() {
}
int Mover::getXPOS() {
    return pMovXPOS;
}
void Mover::setXPOS(int newXPOS) {
    pMovXPOS = newXPOS;
}
int Mover::getYPOS() {
    return pMovYPOS;
}
void Mover::setYPOS(int newYPOS) {
    pMovYPOS = newYPOS;
}
void Mover::DoMove() {
pMovXPOS = pMovXPOS + 1;
pMovYPOS = pMovYPOS + 1;
}
//Compiled with:
g++ -Wall -lm -c Main-Test.cpp
g++ -Wall -lm -c Mover-Test.cpp
g++ -Wall Mover-Test.o Main-Test.o -o world-test.exe -lm
你的问题是这一行:
TempMover = AllMovers.at(iMoverLoop);
Mover您正在创建索引处的副本iMoverLoop,然后修改该副本。向量中的对象永远不会被修改,并且在下一次迭代中您的更改将丢失,因为TempMover会被下一个副本覆盖AllMovers
解决这个问题的一种方法是使用引用来TempMover代替。例如:
Mover& tempMover = AllMovers.at(iMoverLoop);
tempMover.DoMove();