MyTetra Share
Делитесь знаниями!
Работа с памятью
Время создания: 17.10.2017 20:46
Раздел: Знания - Компьютер - Языки программирования - С++
Запись: DuwazSandbox/mytetra/master/base/1508262404jiatcnhsy2/text.html на raw.githubusercontent.com

Язык C: malloc/free

Статья про отказ от освобождения памяти при malloc и free.
https://habrahabr.ru/post/158347/
Жаль, что причины такого поведения скрываются за "такая уж работа malloc" без особой аргументации.
В добавок к комментариям реализацию mmap можно посмотреть тут: https://elixir.free-electrons.com/linux/latest/source/mm/mmap.c

В кратце: При размере равном:

520168 байт и выше — освобождение проходит нормально

520167 байт и ниже — имеем описанную проблему


Язык C++: new/delete

Переменная объектного типа в динамической памяти создаётся в два этапа:

  1. Выделяется память с помощью оператора new.
  2. Вызывается конструктор класса.

Удаляется такая переменная тоже в два этапа:

  1. Вызывается деструктор класса.
  2. Освобождается память с помощью оператора delete.

The new-expression attempts to create an object of the type-id or new-type-id to which it is applied. /*дальше нам не интересно*/

void* operator new(std::size_t size) throw(std::bad_alloc);
Effects: The allocation function called by a new-expression (5.3.4) to allocate size bytes of storage suitably aligned to represent any object of that size.

#include <iostream>

class Test {

public:

Test() {

std::cout << "Test::Test()" << std::endl;

}

void* operator new (std::size_t size) throw (std::bad_alloc) {

std::cout << "Test::operator new(" << size << ")" << std::endl;

return ::operator new(size);

}

};


int main() {

Test *t = new Test();

void *p = Test::operator new(100); // 100 для различия в выводе

}
Этот код выведет следующее

Test::operator new(1)

Test::Test()

Test::operator new(100)

Код взят с https://habrahabr.ru/post/185662/

Язык C++: new[]/delete[]

Массив объектов создаётся в два этапа:

  1. Выделяется память, необходимая для размещения массива объектов.
  2. Для каждого из элементов массива вызывается конструктор по умолчанию.

Удаляется массив объектов тоже в два этапа:

  1. Для всех элементов массива вызываются деструкторы.
  2. С помощью оператора delete освобождается память, занимаемая массивом.

На этапе компиляции неизвестно, на сколько элементов выделяется массив, а значит без использования дополнительной информации невозможно вызвать деструкторы всех элементов массива.

К примеру, механизм создания и удаления массивов объектов может быть реализован следующим образом (рисунок ниже). С помощью функции operator new выделяется размер памяти, равный суммарному размеру всех элементов массива и размеру служебной информации. Оператор new выделяет память и возвращает, допустим, указатель p. По этому указателю записывается служебная информация, а в программу возвращается указатель на первый элемент массива. Аналогично, при вызове delete, в функцию operator delete передаётся не указатель на первый элемент массива, а указатель, на начало блока, выделенного оператором new.

C++ без new и delete
https://habrahabr.ru/company/aligntechnology/blog/283352/

Прекрасное руководство по написанию собственного аллокатора памяти
https://habrahabr.ru/post/148657/

Memory management в ядре Linux. Семинар в Яндексе
https://habrahabr.ru/company/yandex/blog/231957/

 
MyTetra Share v.0.65
Яндекс индекс цитирования