hurnhu
hurnhu

Reputation: 936

C++ crashing when passing pointer to function

what i am trying to do is display my pointer to an array of objects. here is my main program, the function it crashes at is listAll(). if i only enter one object it works, but when i enter a second one it crashes. i am at a loss of what is going wrong. problem occurs after picking menuOption 1 twice and then trying to call list all. i see that the array size is not being increased..

#include <fstream> 
#include <iostream> 
#include <iomanip> 
#include <string>
using namespace std; 

#include "fileStuff.h"

bool menu();
bool menuOptions(int option);
void fileIO();
void listAll(interact * obs, int arryO);

int main() 
{ 

    bool isRunning = true;
    while (isRunning)
    {
        isRunning = menu();
    }
return 0; 
}

bool menu()
{
    int option = 0;
    cout << "1: add new backpack. " << endl
        << "2: delete a backpack "<< endl
        << "3: sort ascending by id " << endl
        << "4: sort descending by id " << endl
        << "5: list all backpacks " << endl
        << "6: quit" << endl;
    cin >> option;
    return menuOptions(option);
}

bool menuOptions(int option)
{

    static int arrayO = 0;
    static interact *obs = new interact[arrayO];
    fileStuff test;
    int tempBagId = 0, tempInvSpaces = 0, tempAmtOfItemsInInv = 0;
    double tempInvMaxWeight = 0.0;
    string tempBagType, tempBagCondish;
    int t = 0 ;
    int i = 0;
    switch (option)
    {
    case 1:
        cout << "bagId? ";
        cin >> tempBagId;
        cout << "How many inv spaces? ";
        cin >> tempInvSpaces;
        cout << "How much weight can the bag hold? ";
        cin >> tempInvMaxWeight;
        (obs + arrayO)->setBagId(tempBagId);
        (obs + arrayO)->setInvSpaces(tempInvSpaces);
        (obs + arrayO)->setInvMaxWeight(tempInvMaxWeight);
        cout << "all stored" << endl;
        arrayO++;
        break;
    case 2:
        //listmanager delete one

        //arrayO--;
        break;
    case 3:
        //sort ascending by id
        break;
    case 4:
        //sort descending by id
        break;
    case 5:
        //list all
        listAll(obs, arrayO);
        break;

    case 6:
        obs = NULL;
        delete obs;
        return false;
        break;
    default:
        break;
    }
}


void listAll(interact * obs, int arryO)
{
int i = 0;
cout << i << endl;
cout << arryO << endl;

}

below is the gists of my class.

#include "listManager.h"
#include <iostream>
#include <string>
using namespace std;

interact::interact()
{
    bagId = 0;
    invSpaces = 0;
    invMaxWeigt = 0;

}

void interact::setBagId(int id)
{
    bagId = id;
}
void interact::setInvSpaces(int spaces)
{
    invSpaces = spaces;
}

void interact::setInvMaxWeight(double weight)
{
    invMaxWeigt = weight;
}

int interact::getBagId()
{
    return bagId;
}
int interact::getInvSpaces()
{
    return invSpaces;
}

double interact::getInvMaxWeight()
{
    return invMaxWeigt;
}

Upvotes: 1

Views: 985

Answers (2)

MatiasFG
MatiasFG

Reputation: 576

You have:

static int arrayO = 0;
static interact *obs = new interact[arrayO];

This will create a dynamic array of 0 length. As Ben stated, the pointer will never change.

The crash is probably caused by trying to access it after increasing the index (arrayO++;), after that it will just be accessing out of bounds memory.

Upvotes: 3

Ben Voigt
Ben Voigt

Reputation: 283624

Your obs points to an array with size zero:

static int arrayO = 0;
static interact *obs = new interact[arrayO];

and never is changed to point to anything larger.

Therefore every attempt to subscript it is an array overrun.

Upvotes: 2

Related Questions