std::move
![]() |
This page has been machine-translated from the English version of the wiki using Google Translate.
The translation may contain errors and awkward wording. Hover over text to see the original version. You can help to fix errors and improve the translation. For instructions click here. |
Déclaré dans l'en-tête <algorithm>
|
||
template< class InputIt, class OutputIt > OutputIt move( InputIt first, InputIt last, OutputIt d_first ); |
(depuis C++11) | |
[first, last)
gamme, à un autre début de la plage à d_first
. Après cette opération, les éléments de la gamme déplacé-de contiendront toujours des valeurs valides du type approprié, mais pas nécessairement les mêmes valeurs que avant le déménagement .[first, last)
, to another range beginning at d_first
. After this operation the elements in the moved-from range will still contain valid values of the appropriate type, but not necessarily the same values as before the move.You can help to correct and verify the translation. Click here for instructions.
Sommaire |
[modifier] Paramètres
first, last | - | la plage d'éléments à déplacer
Original: the range of elements to move The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
d_first | - | le début de la plage de destination. Si d_first est dans [first, last) , std::move_backward doit être utilisé à la place de NJ std :: move </ span> . Original: the beginning of the destination range. If d_first is within [first, last) , std::move_backward must be used instead of NJ std :: move </ span>. </div>The text has been machine-translated via Google Translate. </div></div></div></div>
You can help to correct and verify the translation. Click here for instructions. |
Type requirements | ||
-InputIt must meet the requirements of InputIterator .
| ||
-OutputIt must meet the requirements of OutputIterator .
|
[modifier] Retourne la valeur
You can help to correct and verify the translation. Click here for instructions.
[modifier] Complexité
last - first
déplacer les affectations .last - first
move assignments.You can help to correct and verify the translation. Click here for instructions.
[modifier] Mise en œuvre possible
template<class InputIt, class OutputIt> OutputIt move(InputIt first, InputIt last, OutputIt d_first) { while (first != last) { *d_first++ = std::move(*first++); } return d_first; } |
[modifier] Exemple
Le code suivant déplace des objets de fil (qui eux-mêmes sont pas copiables) d'un récipient à un autre. </ p>
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
#include <iostream>
#include <vector>
#include <list>
#include <iterator>
#include <thread>
#include <chrono>
void f(int n)
{
std::this_thread::sleep_for(std::chrono::seconds(n));
std::cout << "thread " << n << " ended" << '\n';
}
int main()
{
std::vector<std::thread> v;
v.emplace_back(f, 1);
v.emplace_back(f, 2);
v.emplace_back(f, 3);
std::list<std::thread> l;
// copy() would not compile, because std::thread is noncopyable
You can help to correct and verify the translation. Click here for instructions.
std :: move </ span>(v.begin(), v.end(), std::back_inserter(l));
for(auto& t : l) t.join();
}
</div>
You can help to correct and verify the translation. Click here for instructions.
thread 1 ended thread 2 ended thread 3 ended
[modifier] Voir aussi
(C++11) |
se déplace d'une gamme d'éléments vers un nouvel emplacement dans l'ordre inverse Original: moves a range of elements to a new location in backwards order The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (fonction générique) |