使用C ++中的基类和派生类的范围

时间:2015-11-07 04:58:13

标签: c++ object reference scope derived-class

我很难理解我在这里遇到的问题。这是学校课程的作业。我在笔记本电脑上编写代码,并在学校的服务器上编译/测试/提交。

我目前在clion中编写代码。当我在Mac终端上运行gcc -vg++ -v时,我会收到以下信息:

Configured with: --prefix=/Library/Developer/CommandLineTools/usr --with-gxx-include-dir=/usr/include/c++/4.2.1
Apple LLVM version 7.0.0 (clang-700.1.76)
Target: x86_64-apple-darwin15.0.0

在学校的服务器上运行相同的命令:

gcc version 4.4.7 20120313 (Red Hat 4.4.7-16) (GCC)

我正在编译不同版本的gcc,不确定这是否会影响我的问题。起...

int main() {
    int choice; // Used to get creature selection from user
    Creature *creature1, *creature2; // Objects created

    printCreatureList(); // Prints list of creatures for players to select from

    choice = getIntFromUser(5); // Gets user choice for creature selection
    if (choice == 1) {
        Goblin newGob1;
        creature1 = &newGob1;
        newGob1.setStats();

        cout << "Created " << creature1->getName() << " as player 1's creature.\n";
// more if-else, and repeat for player 2 ...
    }

现在,玩家1和玩家2各自拥有一个准备战斗的生物。请注意以后使用,creature1->getName()在此处正常运行。这是战斗循环中给我一个问题的部分。请注意,还有另一个版本,其中玩家2攻击,玩家1进行防御。

    do { // Enter game loop
        cout << endl << "\nTurn #" << i << ", Player 1 (" << creature1->getName() << ") attacking Player 2 (" << creature2->getName() << ")";
        i++;

        p1Attacks(*creature1, *creature2, *p1Achilles, *p2Achilles); // Player 1 attacks, player 2 defends

        if (creature2->getStrength() <= 0) { //Check if creature2 was defeated
            cout << "\n\t***Player 2's creature has taken fatal damage***" << endl;
            cout << "\n\t* * * Player 1 (" << creature1->getName() << ") has won the battle * * *" << endl;
            winCondition = false;
            break;

       // advances on to p2Attacks
     } while (winCondition);

我的p1Attack和p2Attack有类似的格式:

void p1Attacks(Creature &p1, Creature &p2, bool &p1AchillesInjury, bool &p2AchillesInjury)
p1Attacks / p2Attacks工作正常,所有的数学计算都很完美。但是当我在我的学校服务器上进行战斗时,gcc 4.4.7 20120313我看到了:

Turn #1, Player 1 () attacking Player 2 () Player 1's attack roll: 7 Player 2's defend roll: 1 Player 1's damage output: 6 Player 2's armor: 3 Player 2 damage taken: 3 Player 2 new strength: 5

第一行不正确,如果他们各自创建了相应的字符,则应该显示Turn #1, Player 1 (The Barbarian) attacking Player 2 (Reptile)。在我的本地计算机上,代码运行正确,并在括号中拼出名称。

我的生物类和来自creature.cpp的.setStats()示例:

class Creature {
public:
    Creature() {}
/*
    Functions:      changeStrength()
    Description:    Change strength attribute for creature by reducing value
    Parameters:     reduceStrengthBy
    Preconditions:  None
    Postconditions: Strength is reduced
*/
    void changeStrength(int reduceStrengthBy);

    int getAttackDice()     { return attackDice; }
    int getAttackSides()    { return attackSides; }

    int getDefenseDice()    { return defenseDice; }
    int getDefenseSides()   { return defenseSides; }

    int getArmor()          { return armor; }
    int getStrength()       { return strength; }

    std::string getName()   { return name; }

    bool getDodge()         { return dodge; }

protected:
    int attackDice;
    int attackSides;

    int defenseDice;
    int defenseSides;

    int armor;
    int strength;

    std::string name;

    bool dodge;
};

void Reptile::setStats() {
    attackDice = 3;
    attackSides = 6;
    defenseDice = 1;
    defenseSides = 6;
    armor = 7;
    strength = 18;
    name = "The Reptile";
    dodge = false;
}

所以我的最终问题是,为什么我的笔记本电脑和学校服务器上的creature1->getName()行在if statement早期正常运行,但只能在本地计算机上运行而无法正常工作稍后的远程服务器(靠近p1Attack)?

1 个答案:

答案 0 :(得分:1)

如果某个机器上的某些内容有效但另一台机器上却无法运行,则可以确定您已成为未定义行为的受害者

事实上,你正在使用悬空指针。基本上,它归结为:

int main(int, char**) {
  int * pointer; // uninitialised, don't use
  if (someCondition) {
    int object = 42;
    pointer = &object; // assigned to point to an object, can be used
  } // object goes out of scope here
  // pointer is dangling, don't use
  cout << *pointer << endl; // oops
  return 0;
}

要解决此问题,您需要将对象存储在不受自动内存管理影响的位置(例如在堆上)或重新安排代码以利用它。