Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
gomodril
6 / 6 / 0
Регистрация: 10.10.2012
Сообщений: 116
#1

Работа в неуправляемой памяти "куче" - C++

11.05.2013, 18:03. Просмотров 252. Ответов 2
Метки нет (Все метки)

При изучении С++ возник вопрос - используя vector из STL с аллокатором по умолчанию, какие либо действия по очистке памяти предпринимать не нужно? Ведь аллокатор по умолчанию выделяет и высвобождает память сам.
Т.е. если использовать следующий код, то аллокатор используется по умолчанию (не пользовательский) сам все сделает по выделению и высвобождению памяти:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#include <vector>
 
template <class T>
class C2DArray
{
private:
  unsigned size_x;
  unsigned size_y;
  std::vector<T> data;
 
public:
  C2DArray() {}
 
  C2DArray(unsigned new_size_x, unsigned new_size_y)
  {
    resize(new_size_x, new_size_y);
  }
 
  void resize(unsigned new_size_x, unsigned new_size_y)
  {
    data.resize(new_size_x*new_size_y);
    size_x = new_size_x;
    size_y = new_size_y;
  }
 
  T &operator()(unsigned x, unsigned y)
  {
    //Здесь можно assertы поставить...
    return data[y*size_x + x];
  }
 
  const T &operator()(unsigned x, unsigned y) const
  {
    return data[y*size_x + x];
  }
}
и непосредственно сама реализация:
C++
1
2
3
4
5
6
7
8
  C2DArray<int> c;
  c.resize(10, 20);
  c(9, 19) = 10;
 
или 
 
  C2DArray<int> c(10, 20);
  c(9, 19) = 10;
Я правильно понимаю или нет? Спрашиваю т.к. четкого ответа так и не нашел в Интернете.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.05.2013, 18:03     Работа в неуправляемой памяти "куче"
Посмотрите здесь:

C++ напишите программу! тема "динамическое распределение памяти"!
"Утечка " памяти. Да или нет? C++
Поиск значения в памяти приложения ("Нет" читам!) C++
C++ Модель распределения памяти разделами переменного размера с общей очередью, стратегия "наименее подходящий"
Каков смысл в "куче"? C++
C++ Можно ли получить адрес памяти где хранится буква "a"
Ошибка "чтение памяти невозможно" во время перехода к строке с функцией C++
C++ Класс "ArrayList", похоже на проблему с выделением памяти
Что лучше для хранения БД в динамической памяти "Связный список" или же просто в массиве? C++
C++ Могут ли вирусы в "мусоре" оперативной памяти извлечь что то полезное из работы других программ?
Выделение памяти для "треугольного" массива C++
Даны три слова - "мама", "мыла", "раму". Задача - напечатать всевозможные варианты построения слов C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
11.05.2013, 18:13     Работа в неуправляемой памяти "куче" #2
Да. Со стороны C2DArray относительно памяти предпринимать ничего не нужно. Со стороны T стандартные требования к элементам контейнера.

Вот только у вас функция resize неправильно работает: она ж и элементы должна перераспределять в соответствии с новыми размерами.
Croessmah
Модератор
Эксперт CЭксперт С++
12878 / 7264 / 810
Регистрация: 27.09.2012
Сообщений: 17,944
Записей в блоге: 2
Завершенные тесты: 1
11.05.2013, 18:14     Работа в неуправляемой памяти "куче" #3
Цитата из википедии:
Суть идиомы RAII в том, что класс инкапсулирует владение (захват и освобождение) некоторого ресурса — например, открытого файлового дескриптора. Когда объекты-экземпляры такого класса являются автоматическими переменными, гарантируется, что когда они выйдут из области видимости, будет вызван их деструктор — а значит, ресурс будет освобождён.
Yandex
Объявления
11.05.2013, 18:14     Работа в неуправляемой памяти "куче"
Ответ Создать тему
Опции темы

Текущее время: 17:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru