ПРИМЕЧАНИЕ: ЭТО НЕ РАБОТАЕТ С ЭТОЙ ПРАКТИЧЕСКИМ ЭКЗАМЕНОМ, предоставленным нам НАШИМИ ПРОФЕССОРАМИ, ЧТОБЫ ПОМОЧЬ НАМ ПОДГОТОВИТЬСЯ К НАШЕМУ ЭКЗАМЕНУ
Я сейчас учусь на экзамен по программированию. На одном из тестов, которые нам дали, у нас есть следующий вопрос:
Предположим, вы получили шаблонный контейнер, содержащий неупорядоченную коллекцию объектов.
template <typename T>
class Container {
public:
void insert(T *op);
// EFFECTS: inserts the object pointed to by op into
// the container
T *remove();
// EFFECTS: removes an object from the Container, and
// returns a pointer to it. Returns NULL if no
// objects remain in the Container.
// Note: the implementation can choose which
// object to return if more than one exists.
Container(); // ctor
Container(const Container &l); // copy ctor
Container &operator=(const Container &l); // assignment
~Container(); // dtor
private:
...
};
Обратите внимание, что это только интерфейс; детали реализации были опущены для краткости.
Однако вы можете предположить, что реализация основана на узлах; связанный набор узлов
держать объекты.
Вы подозреваете, что реализация деструктора не удовлетворяет правилу сохранения инварианта At-Most-Once, и вместо этого происходит утечка памяти. Напишите приемочный тест (аналогичный тесту в проекте 4), чтобы проверить это условие. Вы должны предоставить подходящий тип содержимого и основную сеть, которая выполняет проверку.
Обратите внимание, что вы не можете зависеть от поведения, которое язык оставляет неопределенным, вы не можете
Предположим, что у вас есть альтернативный распределитель из Project 5, и вы не можете
переопределить оператор удаления. Подсказка: вам разрешено использовать глобальную переменную.
Я хоть что-то вроде:
#include <iostream>
using namespace std;
int *p = NULL;
void leak() {
int *num = new int(5);
p = num;
delete num;
}
int main() {
if ((*p = 6)) {
cout << "Memory leak\n";
} else {
cout << "No Leak\n";
}
}
Основная идея заключается в том, что я не мог записать в пространство памяти, которое я не выделил. При компиляции этого тестового кода, хотя он работает просто отлично, очевидно, вы можете Любые идеи о том, как написать такой контрольный пример?