Function deconstruct
boost::signals2::deconstruct — Create a shared_ptr
with support for post-constructors and pre-destructors.
Synopsis
template<typename T> postconstructor_invoker<T> deconstruct();
template<typename T, typename A1>
postconstructor_invoker<T> deconstruct(const A1 & arg1);
template<typename T, typename A1, typename A2>
postconstructor_invoker<T> deconstruct(const A1 & arg1, const A2 & arg2);
template<typename T, typename A1, typename A2, ..., typename AN>
postconstructor_invoker<T>
deconstruct(const A1 & arg1, const A2 & arg2, ..., const AN & argN);
Description
Создает объект и его владение shared_ptr
(встроено в postconstructor_invoker
) с использованием только одного выделения, таким образом, как boost::make_shared()
. Кроме того, deconstruct
поддерживает постконструкторы и предразрушители. Возвращаемый shared_ptr
завернут внутрь postconstructor_invoker
для того, чтобы предоставить пользователю возможность передать аргументы постконструктору, в то время как обеспечение постконструктора выполняется до того, как обернутый shared_ptr
будет доступен.
Для того, чтобы использовать deconstruct
, вы должны определить постконструктор для вашего класса. Более конкретно, вы должны определить функцию adl_postconstruct
, которая может быть найдена через аргумент-зависимый обзор. Обычно это означает определение функции adl_postconstruct
в том же пространстве имен, что и его связанный класс. См. ссылку на postconstructor_invoker
для спецификации того, какие аргументы передаются adl_postconstruct
.
Дополнительно вы можете определить предразрушитель для вашего класса. Это делается путем определения функции adl_pre destruction
, которая может быть найдена путем анализа. Удалитель shared_ptr
, созданный deconstruct
, сделает неквалифицированный вызов adl_pre destruction
с одним аргументом: указатель объекта, который собирается быть удален. В качестве удобства указатель всегда будет указывать на неконструкционный тип, прежде чем передаваться на adl_pre destruction
. Если не установлена функция adl_pre destruction
, зависящая от пользователя, будет использоваться функция по умолчанию (которая ничего не делает). После того, как называется adl_pre destruction
, удаляющий удаляет объект с помощью checked_delete
.
Любые аргументы, переданные на вызов deconstruct()
, направляются в соответствующий конструктор шаблона типа T
. Аргументы могут также передаваться в классную функцию adl_postconstruct
, используя методы postconstructor_invoker::postconstruct()
.
Заметки: |
>>>>> >>>>>>>> Для того, чтобы передать неконечные ссылки конструктору, вам нужно будет обернуть их в контрольные обертывания с помощью бустера::ref. Вы можете предоставить всем deconstruct перегрузкам доступ к частным и защищенным конструкторам вашего класса, объявив deconstruct_access друга. Использование частных конструкторов в сочетании с deconstruct_access может быть полезным для обеспечения того, чтобы ваши объекты были созданы только deconstruct , и, таким образом, их постконструкторы или предразрушители всегда будут называться. |
Возвращение: |
A postconstructor_invoker владеет недавно выделенным объектом типа T . |