Пространства имён
Варианты
Действия

std::set_new_handler

Материал из cppreference.com
< cpp‎ | memory‎ | new

 
 
 
 
Низкий уровень управления памятью
Функции
Оригинал:
Functions
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
operator new
operator new[]
operator delete
operator delete[]
get_new_handler(C++11)
set_new_handler
Классы
Оригинал:
Classes
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
bad_alloc
bad_array_new_length(C++11)
nothrow_t
Типы
Оригинал:
Types
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
new_handler
Objects
Оригинал:
Objects
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
nothrow
 
Определено в заголовочном файле <new>
std::new_handler set_new_handler(std::new_handler new_p)
Делает new_p новой глобальной новые функции обработчика и возвращает ранее установленный нового обработчика.
Оригинал:
Makes new_p the new global new-handler function and returns the previously installed new-handler.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

Содержание

[править] Notes

попытка выделение памяти. Его назначением является одной из трех вещей:
Оригинал:
The new-handler function is the function called by
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
1)
сделать более доступной памяти
Оригинал:
make more memory available
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
2)
завершить программу (например, по std::terminate вызова)
Оригинал:
terminate the program (e.g. by calling std::terminate)
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
3)
бросать исключение типа std::bad_alloc или полученные из std::bad_alloc
Оригинал:
throw exception of type std::bad_alloc or derived from std::bad_alloc
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
Если нового обработчика возвращает, распределение функций повторяет ранее не удалось распределения попытки и называет нового обработчика снова, если распределение снова не удалось. Для завершения цикла нового обработчика можно назвать std::set_new_handler(nullptr): если, после неудачной попытки распределения, распределения функций считает, что std::get_new_handler возвращает нулевое значение указателя, он будет бросать std::bad_alloc.
Оригинал:
If new-handler returns, the allocation function repeats the previously-failed allocation attempt and calls the new-handler again if the allocation fails again. To end the loop, new-handler may call std::set_new_handler(nullptr): if, after a failed allocation attempt, allocation function finds that std::get_new_handler returns a null pointer value, it will throw std::bad_alloc.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
При запуске программы, нового обработчика является нулевой указатель.
Оригинал:
At program startup, new-handler is a null pointer.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

[править] Параметры

new_p -
указатель на функцию типа std::new_handler, или нулевой указатель
Оригинал:
pointer to function of type std::new_handler, or null pointer
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

[править] Возвращаемое значение

Ранее установленный новый обработчик, или нулевое значение указателя, если ни один не был установлен.
Оригинал:
The previously-installed new handler, or a null pointer value if none was installed.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

[править] Исключения

noexcept-спецификация:  
noexcept
  (начиная с C++11)

[править] Пример

#include <iostream>
#include <new>
void handler()
{
    std::cout << "Memory allocation failed, terminating\n";
    std::set_new_handler(nullptr);
}
int main()
{
    std::set_new_handler(handler);
    try {
        while(true)
            new int[100000000ul];
    }catch(const std::bad_alloc& e) {
        std::cout << e.what() << '\n';
    }
}

Вывод:

Memory allocation failed, terminating
std::bad_alloc

[править] См. также

Распределение функций
Оригинал:
allocation functions
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

(функция) [edit]
set_new_handler
регистрирует новый обработчик
Оригинал:
registers a new handler
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

(функция) [edit]
указатель на функцию типа нового обработчика
Оригинал:
function pointer type of the new handler
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

(определение типа) [edit]
исключение, когда на выделение памяти
Оригинал:
exception thrown when memory allocation fails
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

(класс) [edit]