chsvlib
chsv helper source code

◆ move()

void Chusov::Memory::move ( InputIterator  start,
InputIterator  end,
OutputIterator  output 
)
noexcept

Move-assigns a sequence of elements addressed by a pair of input iterators to a destination specified by an output iterator.

Template Parameters
InputIteratorThe type of an input iterator which addresses the input sequence of elements to move.
OutputIteratorThe type of an output iterator specifying the destination of the move operation.
Parameters
startThe input iterator associated with the beginning of the input sequence of elements to move.
endThe input iterator associated with the past-the-end position of the input sequence.
outputThe output iterator.
Returns
The output iterator after the move operation, i.e. the iterator associated with the position in the destination after the last moved-in element, or output, if the input sequence is empty.
Exceptions
Anyexception that originates from move-assignment of the sequence elements.

The function behaves exactly like the standard std::move except that the input and output sequences must not overlap in memory.

If the move-assignment is direct, i.e. dereferencing of the output iterator yields an actual address in memory rather than some proxy, and the assignment used is defined for two objects of the type T, then the output sequence must contain valid elements of the type T prior to the operation, i.e. the destination memory must not be uninitialized. To move into uninitialized memory, use construct_move.

Examples
chsvmath\algebraic_traits.cpp.