InputByteStreamOwn::operator=: различия между версиями

Материал из CAMaaS preliminary wiki
Перейти к навигации Перейти к поиску
(Новая страница: «{{function_begin|InputByteStreamOwn& operator{{=}}(const InputByteStreamOwn&) {{=}} delete; InputByteStreamOwn& operator{{=}}(InputByteStreamOwn&& right);|{{Input…»)
 
 
(не показана 1 промежуточная версия этого же участника)
Строка 1: Строка 1:
{{function_begin|InputByteStreamOwn& operator{{=}}(const InputByteStreamOwn&) {{=}} delete;
{{function_begin|InputByteStreamOwn& operator{{=}}(InputByteStreamOwn&& right); //1
InputByteStreamOwn& operator{{=}}(InputByteStreamOwn&& right);|{{InputByteStreamOwn::operator{{=}} brief}}
template <class RightAdapterType>
# Удаленный оператор присваивания с копированием.
InputByteStreamOwn& operator{{=}}(RightAdapterType&& right); //2
# Оператор присваивания с перемещением. Деассоциирует текущий экземпляр адаптера [[InputByteStreamOwn]] от владеемого объекта, если это владение имело место до вызова, затем передает объект, ассоциированный с <tt>right</tt>, и его владение текущему экземпляру адаптера и диассоциирует <tt>right</tt> от объекта.}}
|{{InputByteStreamOwn::operator{{=}} brief}}
{{function paramlist begin}}
# Оператор присваивания с перемещением, который переносит владение реализацией потока адаптеру {{cpp_this}}. Присваивание адаптеру разрешено, только если он не был до этого проинициализирован действительным адресом реализации потока или  был сброшен с помощью [[InputByteStreamOwn::release_ownership]] или [[InputByteStreamOwn::reset_ownership]] без параметров. В противном случае генерируются исключения - [https://www.chusov.org/doxygen/struct_chusov_1_1_exceptions_1_1_unsupported_call_exception.html Chusov::Exceptions::UnsupportedCallException], если {{param|right}} не содержит реализации [[IInputByteStream]], и [https://www.chusov.org/doxygen/struct_chusov_1_1_exceptions_1_1_invalid_parameter_exception.html Chusov::Exceptions::InvalidParameterException] - в противном случае.
{{function paramlist add|right|Иной экземпляр адаптера, состояние которого передается текущему экземпляру в результате присваивания с перемещением. После вызова <source lang="cpp" inline>right.get_interface() == nullptr</source>.}}
# Аналогично, но с приведением типа указателя на реализацию с <source lang="cpp" inline>typename std::remove_reference_t<RightAdapterType>::interface_type*</source> к типу <source lang="cpp" inline>IInputByteStream*</source>. Данная перегрузка участвует в процедуре разрешения перегрузок, только если <source lang="cpp" inline>RightAdapterType&&</source> является rvalue-ссылкой, тип <source lang="cpp" inline>std::decay_t<RightAdapterType></source> является [[владеющий адаптер|адаптером с владением]] с подтипом <tt>interface_type</tt>, указатель на который неявно приводим к <source lang="cpp" inline>IInputByteStream*</source>.}}
{{function paramlist end}}
{{function template paramlist begin}}
{{function template paramlist add|RightAdapterType|Тип адаптера с владением реализацией интерфейса [[IInputByteStream]] (или неявно приводимого к нему интерфейса), которая передается экземпляру {{cpp_this}} адаптера перегрузкой 2. Тип <source lang="cpp" inline>std::decay_t<RightAdapterType></source> должен задавать адаптер с владением через указатель, приводимый к типу <source lang="cpp" inline>IInputByteStream*</source>.}}
{{function template paramlist end}}
{{function_paramlist begin}}
{{function_paramlist add|right|Адаптер, передающий владение своим интерфейсным указателем, если он есть, создаваемому экземпляру [[InputByteStreamOwn]], как если бы был выполнен вызов <source lang="cpp" inline>right.release_ownership()</source>.}}
{{function_paramlist end}}
{{function_return_value|Ссылка на <source lang="cpp" inline>*this</source>.}}
{{function_end}}
{{function_end}}
Для адаптеров <tt>x</tt> и <tt>y</tt> типа [[InputByteStreamOwn]] в точке доступа к методу [[InputByteStreamRef::reset_interface]] вызов
<source lang="cpp>
x = std::move(y);
</source>
эквивалентен вызовам
<source lang="cpp">
if (&x != &y)
    x.reset_interface(y.release_ownership());
</source>

Текущая версия на 22:06, 11 августа 2019

InputByteStreamOwn& operator=(InputByteStreamOwn&& right); //1
template <class RightAdapterType>
InputByteStreamOwn& operator=(RightAdapterType&& right); //2

Оператор присваивания с перемещением.

  1. Оператор присваивания с перемещением, который переносит владение реализацией потока адаптеру this. Присваивание адаптеру разрешено, только если он не был до этого проинициализирован действительным адресом реализации потока или был сброшен с помощью InputByteStreamOwn::release_ownership или InputByteStreamOwn::reset_ownership без параметров. В противном случае генерируются исключения - Chusov::Exceptions::UnsupportedCallException, если right не содержит реализации IInputByteStream, и Chusov::Exceptions::InvalidParameterException - в противном случае.
  2. Аналогично, но с приведением типа указателя на реализацию с typename std::remove_reference_t<RightAdapterType>::interface_type* к типу IInputByteStream*. Данная перегрузка участвует в процедуре разрешения перегрузок, только если RightAdapterType&& является rvalue-ссылкой, тип std::decay_t<RightAdapterType> является адаптером с владением с подтипом interface_type, указатель на который неявно приводим к IInputByteStream*.
Параметры шаблона
RightAdapterTypeТип адаптера с владением реализацией интерфейса IInputByteStream (или неявно приводимого к нему интерфейса), которая передается экземпляру this адаптера перегрузкой 2. Тип std::decay_t<RightAdapterType> должен задавать адаптер с владением через указатель, приводимый к типу IInputByteStream*.
Параметры
rightАдаптер, передающий владение своим интерфейсным указателем, если он есть, создаваемому экземпляру InputByteStreamOwn, как если бы был выполнен вызов right.release_ownership().
Возвращаемое значение:
Ссылка на *this.