Les conteneurs, hérités d’un autre temps ?

La STL, la bibliothèque standard de templates du C++, fournit un concept très intéressant pour le développement : il s’agit des conteneurs.

Qu’est-ce qu’un conteneur ?

Un conteneur (container) est, comme son nom l’indique, un objet qui contient d’autres objets.

Il s’agit d’un objet contenant d’autres objets. Il propose toujours quelques fonctionnalités concernant ces objets contenus : au strict minimum, l’ajout et la suppression. Parfois aussi, l’insertion, le tri, la recherche… Ils fournissent aussi des itérateurs, qui permettent de les utiliser dans des boucles en passant par tous les éléments.

Qt fournit aussi des conteneurs, qui reprennent le concept de la STL. Les itérateurs sont aussi disponibles, mais une nouvelle instruction, foreach, est aussi disponible.

Voici le code que vous devez rédiger en C++ :

#include <vector>
std::vector<int> s;
for (std::vector<int>::iterator it = s.begin(); it != s.end(); )
{
    if (*it == 5)
        it = s.erase(it);
    else
        ++it;
}

Et voici un autre code, qui exploite ce nouveau mot-clé :

QStringList list;
list << "C" << "C++" << "Qt";
QList<QByteArray> ipListEnCharData;
QList<const char*> ipListEnChar;
foreach(QString ip, list)
{
      QByteArray adresseIpEncodee = ip.toUtf8();
      ipListEnChar << adresseIpEncodee.constData();
      ipListEnCharData << adresseIpEncodee;
}
foreach(const char *str, ipListEnChar)
{
    printf(str);
}

Laisser un commentaire