malloc — Помощь с ошибкой выделения памяти в c ++, linux с использованием g ++

Я искал других с такой же проблемой, как у меня, но у них у всех код сильно отличается от меня.

Когда я компилирую следующий код с g ++, я получаю сообщение об ошибке:

basketbOOP: malloc.c: 2451: sYSMALLOc: утверждение `(old_top == (((mbinptr) (((char *) &((av) -> bins [((1) — 1) * 2])) — __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) || ((unsigned long) (old_size)> = (unsigned long) ((((__ builtin_offsetof (struct malloc_chunk, fd_nextsize)) + ((2 * (sizeof (size_t))) — 1)) & ~ ((2 * (sizeof (size_t))) — 1))) && ((Old_top) -> размер & 0x1) && ((без знака долго) old_end & маска страницы) == 0) ‘не удалось.
Прервано (ядро сброшено)

Я никогда не использую free () или подобные функции, поэтому я не думаю, что это проблема.

Когда я запускаю свой код через valgrind, я получаю «Неверная запись размера 4». а потом какой-то бред, который я не совсем понимаю, указывая на меня, я думаю, на конструктор Player.

Для тех, кто интересуется, это программа симуляции баскетбольного мяча, которую я пишу для задания, чтобы помочь изучить и понять ООП, поэтому, очевидно, я НЕ прошу вас написать мой код для меня, это просто ошибка, с которой я никогда не сталкивался раньше и Нужно исправить это, чтобы продолжить выполнение задания.

PS: извините за отсутствие комментариев, я еще не дошел до этого: /
pps: форматирование может выглядеть странно из-за того, что мне пришлось делать отступ для кода, чтобы все это отображалось как код

Спасибо всем, кто помогает заранее!

#include <iostream>
#include <time.h>
#include <string>
#include "/home/craig/Programming/GeneralFunction (1).h"using namespace std;class player {
private:
int percent[3];
string name;
int shots[3];
int made[3];
bool MVP;

public:
player(int i){
for (int n = 0; n < 3; n++){
shots[i] = 0;
made[i] = 0;
}
MVP = false;
cout << "What is player #" << i << "'s name? ";
if (i != 1){
cin.clear();
cin.ignore();
}
getline(cin, name);
for (int n = 0; n < 3; n++){
cout << "What is " << name << "'s " << n+1 << "pt Shot Percentage? ";
cin >> percent[n];
if (percent[n] < 0){
cout << "Because you entered a Percent lower than 0%, the percent has been set to 0%. \n";
percent[n] = 0;
}
if (percent[n] > 100){
cout << "Because you entered a Percent greater than 100%, the percent has been set to 100%. \n";
percent[n] = 100;
}
}//for
}//player constructor

~player(){
cout << "Deleting " << name << endl;
}

void RandomPlay(int point){

switch(point){
case 0:
switch(rand()%2){
case 0:
cout << name << " is fouled. " << name << " takes the foul shot and... ";
break;
case 1:
cout << name << " takes a free throw and...";
break;
}//switch 2
break;//1 point

case 1:
switch(rand()%4){
case 0:
cout << name << " goes Up for a lay-up and...";
break;
case 1:
cout << name << " jumps for a SlamDunk and...";
break;
case 2:
cout << name << " shoots a jump shot and...";
break;
case 3:
cout << name << " attempts a field goal from inside the three point line and...";
break;
}//switch 4
break;//2 point

case 2:
switch(rand()%2){
case 0:
cout << name << " shoots a three pointer and...";
break;
case 1:
cout << name << " attempts a field goal from outside the three point line and...";
break;
}
break;//three point
}//switch point
}//RandomPlayint TakeShot(){
int point = rand()%3;
RandomPlay(point);
shots[point]++;
if (rand()%100+1 <= percent[point]){
made[point]++;
return (point+1);
}
return 0;
}

void DispPlayerStats(){
cout << "PLayer: " << name << endl;
for (int i = 0; i < 3; i++){
cout << i+1 <<" point shot Percent: " << percent[i] << "%" << endl;
cout << i+1 << "pt Shots Taken: " << shots[i] << endl;
cout << i+1 <<"pt Shot Baskets Made: " << made[i] << endl;
}
if (MVP)
cout << name << " was the Most Valuable Player on the Team!" << endl;
}

};

class team {
private:
player *ptrPlayer[5];
string teamName;
static int score;

public:
team(int i){
cout << "What is this teams name? ";
if (i != 1){
cin.clear();
cin.ignore(10000, '\n');
}
getline(cin, teamName);
cout << "Enter Player info for Team " << teamName << ":" << endl;
for (int i = 0; i < 5; i++){
ptrPlayer[i] = new player(i+1);
}
}

string GetName(){

return teamName;
}int Play(int score){
int oldScore = score;
score += ptrPlayer[rand()%5]->TakeShot();
if (oldScore == score)
cout << " misses!" << endl;
else
cout << " makes it! " << score - oldScore << " more points for Team " << teamName << "!" << endl;

return score;
}

};

int main(){
int score[2] = {0, 0};
SeedRand();
char PbP;
char enter = 1;
team *ptrTeam[2];
for (int i = 0; i < 2; i++){
cout << "ENTER INFO FOR TEAM " << i+1 << ":" << endl;
ptrTeam[i] = new team(i+1);
}
//CLS;
cout << "Would you like a Play by Play? [y/n] ";
cin >> PbP;
while (PbP != 'y' && PbP != 'Y' && PbP != 'N' && PbP != 'n'){
cout << "Invalid Choice: Would you like a Play by Play? [y/n] ";
cin >> PbP;
}
cout << "TIME TO PLAY BASKET BALL! " << endl;
cout << "The " << ptrTeam[0]->GetName() << " versus The " << ptrTeam[1]->GetName() << "!" << endl;for (int quarter = 1; quarter < 5; quarter++){
//CLS;

cout << score[0] << " - " << score[1] << endl;
for (int pos = 0; pos < 30; pos++){
score[pos%2] = ptrTeam[pos%2]->Play(score[pos%2]);
if (PbP == 'y' || PbP == 'Y')
do {
cout << "Press x to continue." << endl;
cin >> enter;
}while(enter != 'x' || enter != 'X');
}

}//for quarterreturn 0;
}

1

Решение

Взгляните еще раз на это:

for (int n = 0; n < 3; n++){
shots[i] = 0;
made[i] = 0;
}
4

Другие решения

Я не очень хорошо разбираюсь в C ++, поэтому не смогу полностью вам помочь, но раньше уже видел почти такое же сообщение об ошибке. Это произошло из-за перезаписи памяти за пределами моего выделенного блока, скорее всего, данных, которые malloc использует внутренне. Это ошибка «индекс массива вне границ».

Поскольку я не могу скомпилировать ваш код без /home/craig/Programming/GeneralFunction (1).hЯ не вижу сообщения valgrind. Было бы полезно, если бы вы либо опубликовали вывод valgrind, либо достаточно кода для его компиляции.

0

По вопросам рекламы [email protected]