Bibliothèque de pile C ++ - fonction stack ()

La description

Le constructeur de déplacement C ++ std::stack::stack() construit la pile avec le contenu des autres en utilisant la sémantique de déplacement.

Déclaration

Voici la déclaration du constructeur std :: stack :: stack () sous forme d'en-tête std :: stack.

C ++ 11

template <class Alloc>
stack (stack&& x, const Alloc& alloc);

Paramètres

  • x - Objet de pile du même type.

  • alloc - Objet Allocator.

Valeur de retour

Le constructeur ne renvoie jamais de valeurs.

Des exceptions

Cette fonction membre ne lève jamais d'exception.

Complexité temporelle

Linéaire ie O (n)

Exemple

L'exemple suivant montre l'utilisation du constructeur std :: stack :: stack ().

#include <iostream>
#include <stack>

using namespace std;

int main(void) {   
   stack<int> s1;

   for (int i = 0; i < 5; ++i)
      s1.push(i + 1);

   cout << "Size of stack s1 before move operation = " << s1.size() << endl;

   stack<int> s2(move(s1));

   cout << "Size of stack s1 after move operation = " << s1.size() << endl;

   cout << "Contents of stack s2" << endl;
   while (!s2.empty()) {
      cout << s2.top() << endl;
      s2.pop();
   }

   return 0;
}

Compilons et exécutons le programme ci-dessus, cela produira le résultat suivant -

Size of stack s1 before move operation = 5
Size of stack s1 after move operation = 0
Contents of stack s2
5
4
3
2
1