CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[C++][queue]parcourir une queue

guidono4
guidono4
Niveau 5
17 décembre 2009 à 11:14:05

Salut ! Je viens d'apprendre à utiliser les queue mais je ne comprend pas comment faire pour la parcourir sachant que je ne veux pas la vider (car je sais faire en la vidant).
Je voudrais quelque chose de ce genre là :

for(int i = 0; i < tab_text.size(); i++) {
tab_text(i)->ecouter(event);
}

mais voici l'erreur :
error: no match for call to '(std::queue<GlineText*, std::deque<GlineText*, std::alloc...

pour info je suis sur code::blocks et cette queue contient des pointeurs vers des GLineText.

Voilà, en espérant que vous pourrez m'aider !

_skip
_skip
Niveau 10
17 décembre 2009 à 12:00:15

La std::queue est pas itérable à ma connaissance. dqueue et list sont peut être de meilleurs candidats pour ce que tu veux faire.

Par ailleurs, attention avec ton exemple, on ne parcourt pas n'importe quelle structure de donnée en accédant aux éléments par index comme si c'était un std::vector<> car ça peut être catastrophique coté performance.

godrik
godrik
Niveau 30
17 décembre 2009 à 16:10:04

en effet, la std::queue n'est pas iterable : http://www.sgi.com/tech/stl/queue.html

Cependant, par default, c'est implemente dans une deque http://www.sgi.com/tech/stl/Deque.html. Donc utiliser une deque directement pourrait etre plus pertinent. Apres tout depend de l'utilisation.

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment