IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Threads & Processus C++ Discussion :

écrire avec un thread et lire avec un autre


Sujet :

Threads & Processus C++

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut écrire avec un thread et lire avec un autre
    Bonjour,

    J'essai de faire un programme qui lit et écrit en même temps. Le premier thread à terme sera différent mais ce sera qui il écrira continuellement sur le .txt.
    Le deuxième thread doit traiter une par une les lignes du document quand elles sont complètes.
    J'ai donc fait le programme ci-dessous avec level qui devrait indiquer le nombre de lignes et donc si il reste des lignes à traiter. Mais il n'affiche rien.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    #include <iostream>
    #include <thread>
    #include <windows.h>
    #include <fstream>
    #include <string>
    #include <sstream>
    #include <mutex>
     
    using namespace std;
     
    int main()
    {   mutex lock;
        string line, checker;
        ostringstream data;
        int h=0,m=0,level=0;
        float s=0;
     
        fstream myfile;
        if (myfile.is_open()) myfile.close();
        myfile.open("data.txt",ios::out | ios::in | ios::trunc);
        thread t1 ([&h,&s,&m,&myfile,&data,&checker,&level](){
     
                  while(1)
                    {s+=0.1;
                    if (s==60)
                        {s=0;m+=1;}
                    if (m==60)
                        {m=0;h+=1;}
                    if (myfile.is_open()){
                    data<<h<<" "<<m<<" "<<s<<endl;
                    checker=data.str();
                    if(checker.find("\n")) level+=1;
     
                                         }
     
                    Sleep(100);
     
     
     
                  }
                  });
        thread t2 ([&h,&m,&s,&myfile,&line,&level,&lock](){
     
                   while(1){
     
     
                     if (myfile.is_open()&& level>0){
                        lock.lock();
                        myfile.seekg(0,myfile.beg);
                        getline(myfile,line);
                        lock.unlock();
                        cout<<line;
                        level-=1;
                     }
     
     
                  }
                  });
     
     
        t1.join();
        t2.join();
        myfile.close();
        return 0;
    }
    Merci pour votre aide.

  2. #2
    Expert éminent
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 565
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 565
    Points : 7 648
    Points
    7 648
    Par défaut
    Bonjour,

    L'avantage des threads c'est cela permet à d'avoir des flux d'exécution qui partagent un même espace mémoire.
    Mais attention, il ne faut pas oublier l'énorme inconvénient des threads : on peut utiliser les mêmes données entre plusieurs threads! Et c'est souvent catastrophique.
    Il faut donc tout faire pour qu'il n'y ait pas d'accès simultané aux mêmes données.
    Le mieux est de n'avoir rien en commun et d'utiliser des mécanismes de communication.
    Si on s'y est mal pris, en dernier ressort on peut utiliser des mutex ou des mécanismes de synchro.

    Ici les objets utilisés par les deux threads : myfile et level.
    Inversement un mutex qui ne serait utilisé que par un thread ne sert à rien (il faut garantir que les 2 ne font pas en même temps qqchose), donc lock n'est certainement pas utilisé correctement ici.
    myfile est donc utilisé par 2 threads, ce qui n'a aucun sens. Cet objet est rempli de variables gérant la communication avec un fichier. On ne peut pas avoir 2 threads qui partagent cet objet. Attention, je n'ai jamais dit que deux threads ne pouvaient pas accéder à un unique fichier en même temps.

  3. #3
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Juin 2009
    Messages
    4 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 481
    Points : 13 679
    Points
    13 679
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    int main()
    {   mutex lock;
        string line, checker;
        ostringstream data;
        int h=0,m=0,level=0;
        float s=0;
     
        // reste du code
    }
    Woh ! On est plus en C89 ! Il faut déclarer et initialiser ses variables au plus proche de l'endroit où on commence à s'en servir ! Ca évite des erreurs et ça augmente surtout la lisibilité.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    fstream myfile;
        if (myfile.is_open()) myfile.close();
    Je ne pense pas que le fichier puisse être ouvert vu que tu n'appelles pas open()...

    Et sinon de manière plus globale, pourquoi passer par un fichier ? Ce qu'il te faut, c'est une queue protégée par un mutex que tu partages entre tes deux threads. Le thread producteur mets les éléments au fur et à mesure qu'ils sont prêts ; le thread consommateur les lit au fur et à mesure qu'il finit de traiter les précédents.

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    Merci pour vos réponses.

    Donc si j'ai bien compris, je dois ouvrir le fichier avec un objet différent pour chacun de thread et mieux utiliser le mutex pour gérer la variable level .
    Pour rapport à l'initialisation des variables: je la met just avant le thread 1 du coup?



    Citation Envoyé par Bktero Voir le message
    Et sinon de manière plus globale, pourquoi passer par un fichier ?
    J'ai besoin pendre les données qui arrivent par un port rs232 jusqu'au retour à la ligne. Le fichier me semblait une méthode adaptée puisque je pouvais écrire toutes les données qui arrivent et "couper" là où j'ai besoin.
    Je ne connais pas très bien les queues. D'après ce que tu dit elles ont l'air de fonctionné sur le principe FIFO je vais me renseigner et peut-être essayer cette méthode.

    Merci encore,

  5. #5
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Juin 2009
    Messages
    4 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 481
    Points : 13 679
    Points
    13 679
    Billets dans le blog
    1
    Par défaut
    En gros, ton thread T1 récupère des caractères depuis la liaison RS232, les mets dans un fichier, puis ton thread T2 relit le fichier pour le traiter ?

  6. #6
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    Oui,c'est ça.

  7. #7
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Juin 2009
    Messages
    4 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 481
    Points : 13 679
    Points
    13 679
    Billets dans le blog
    1
    Par défaut
    Pourquoi ne pas faire :
    - T1 mets les caractères lus dans un stockage temporaire (au hasard, un std::ostringstream)
    - Quand T1 rencontre '\n', il récupère une std::string de son stockage temporaire, pousse cette std::string dans une std::queue
    - T1 remet à 0 son stockage et recommence sa quête d'un '\n'
    - T2 attend qu'un élément soit disponible dans la std::queue
    - T2 traite cet élément (une std::string)

    Il faudra sûrement un std::mutex pour protéger les accès à la std::queue.

  8. #8
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    Merci,
    Je vais essayer ça quand je me serais familiarisé avec les queues et les ostringstreams.

  9. #9
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 115
    Points : 32 967
    Points
    32 967
    Billets dans le blog
    4
    Par défaut
    Passer par un fichier est de loin la pire solution, et ton cas ne fait pas exception.
    Surtout quand tout ce qui t'intéresse c'est des lignes entières.
    Tu reçois les données, les pousses dans une structure intermédiaire. (ostringstream pourquoi pas, mais un bête vector est au moins aussi bien)
    Puis tu parses cette structure pour vérifier les éventuels fins de ligne.
    Pour chaque fin de ligne trouvée, tu split et pousses les données dans la structure partagée entre les threads.
    Le temps de lock est minimal et tu tues pas tes perfs à faire de la lecture/écriture sur un fichier.
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  10. #10
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    Merci à tous,
    Avec ce que j'ai retenu de vos commentaires j'ai fait le code ci-joint. Mais je n'ai pas très bien compris comment fonctionnait les queue et j'en aurai surement besoin si la fréquence des entrées augmente.
    De plus il y a quelques bugs dans mon programme dont je ne parviens pas à identifier la source. (un très visible quand on lance le programme et l'autre est que le programme retourne parfois au début).
    J’aurais donc encore besoin de quelques conseils.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    #include <iostream>
    #include <thread>
    #include <windows.h>
    #include <fstream>
    #include <string>
    #include <sstream>
    #include <mutex>
    #include <stdlib.h>
     
    using namespace std;
     
    int main()
    {   mutex lock;
        string entry="",output,entry2="",output2;
        stringstream stream;
        stringstream stream2;
        int i,n,r;
        int h=0,m=0;
        float s=0;
        thread t1 ([&h,&s,&m,&entry,&entry2,&stream,&n,&stream2,&i,&output,&r,&lock](){
     
     
     
                  while(1)
                    {s+=0.1;
                    if (s==60)
                        {s=0;m+=1;}
                    if (m==60)
                        {m=0;h+=1;}
                    stream<<h<<" "<<m<<" "<<s<<endl;
                    entry=stream.str();
     
                    r=5;
                    entry2=entry.substr(r,n-1);
                    entry=entry.substr(0,r-1);
                    entry=entry2+entry;    //entry est juste une simulation d'une entrée que je pourais obtenir.
                    n=entry.length();
                    for(i=0;i<n;i++)
                        {
     
     
                         if(entry [i]=='\n')
                           {
     
                           lock.lock();
                           output=stream2.str();
                           lock.unlock();
                           stream2.str("");
                           }
                        else{stream2<<entry[i]; }
     
     
     
     
                        }
     
     
                    Sleep(100);
     
     
     
                  }
                  });
        thread t2 ([&output,&output2,&lock](){
     
                   while(1){
                    lock.lock();
                    output2=output,
                    output="";
                    lock.unlock();
                    if(output2!="")
                       {
                        try{
                           cout<<"h= "<<output2.substr(0,output2.find(" "));
                           output2=output2.substr(output2.find(" ")+1);
                           cout<<" m= "<<output2.substr(0,output2.find(" "));
                           output2=output2.substr(output2.find(" ")+1);
                           cout<<" s= "<<output2.substr(0,output2.find(" "))<<endl;
                           }
                        catch(std::out_of_range& er){}
                        catch(std::invalid_argument& e){}
     
                           }
                  }
                  });
     
     
        t1.join();
        t2.join();
     
        return 0;
    }

  11. #11
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    J'ai essayé de corriger mon programme, mais il n'agit toujours pas comme ce que j'avais prévu. Quand j'affiche stream2.str() c'est correcte au début mais ou bout d'un moment il manque des charactéres. Et quand je lance mon programme tel qu'il est là , il n'y a aucune sortie alors que je m'attendais au moins à ce que output2 soit identique à stream2.str().
    Si quelqu'un pouvais me donner un coup de main je le remercie d'avance.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    #include <iostream>
    #include <thread>
    #include <windows.h>
    #include <fstream>
    #include <string>
    #include <sstream>
    #include <mutex>
    #include <stdlib.h>
    #include <queue>
     
    using namespace std;
     
    int main()
    {   mutex lock;
        string entry="",entry2="",output2;
        stringstream stream;
        stringstream stream2;
        int i,n,r,position;
        int h=0,m=0;
        float s=0;
        queue <string> output;
        thread t1 ([&h,&s,&m,&position,&entry,&entry2,&stream,&n,&stream2,&i,&output,&r,&lock](){
     
     
     
                  while(1)
                    {s+=0.1;
                    if (s==60)
                        {s=0;m+=1;}
                    if (m==60)
                        {m=0;h+=1;}
                    stream<<h<<" "<<m<<" "<<s<<endl;;
                    entry=stream.str();
                    stream.str("");
                    //entry+="\n";
     
                    n=entry.length();
     
     
     
                    r=5+(int)(10*s)%4;
                    entry=entry2+entry;
                    entry2=entry.substr(r,n);
                    entry=entry.substr(0,r);//entry est juste une simulation d'une entrée que je pourais obtenir.
                    n=entry.length();
     
                    for(i=0;i<n;i++)
                        {
     
     
                        stream2<<entry[i];
                        if(entry[i]=='\n')
                           {
                            lock.lock();
                            output.push(stream2.str());
                            lock.unlock();
                            stream2.str("");
     
                           }
     
     
                       }
     
     
     
                    Sleep(100);
     
     
     
                  }
                  });
        thread t2 ([&output,&output2,&lock](){
     
                   while(1){
                    lock.lock();
                    if(!output.empty()) output2=output.front(),
                    lock.unlock();
                    cout<<output2;
                    if(output2!="")
                       {
                        try{
                           cout<<"h= "<<output2.substr(0,output2.find(" "));
                           output2=output2.substr(output2.find(" ")+1);
                           cout<<" m= "<<output2.substr(0,output2.find(" "));
                           output2=output2.substr(output2.find(" ")+1);
                           cout<<" s= "<<output2.substr(0,output2.find(" "))<<endl;
                           }
                        catch(std::out_of_range& er){}
                        catch(std::invalid_argument& e){}
     
                           }
                  }
                  });
     
     
        t1.join();
        t2.join();
     
        return 0;

  12. #12
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Juin 2009
    Messages
    4 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 481
    Points : 13 679
    Points
    13 679
    Billets dans le blog
    1
    Par défaut
    Ton code est pas mal bordélique... Tu gagnerais à clarifier un peu tout ça. Ça passe par l'indentation, des lambdas qui n'ont pas 36 paramètres(*), des variables mieux nommées que entry1 / entry2...

    (*) Soit tu utilises des captures par défaut (genre [&]), soit tu remarques que la plupart des variables peuvent être déclarés à l'intérieur de tes threads. Je t'ai dit plutôt qu'on n'était plus en C89, je le maintiens

    Un code basique qui fait ce que tu veux, c'est ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    #include <iostream>
    #include <mutex>
    #include <queue>
    #include <sstream>
    #include <thread>
     
    int main(int, char*[]) {
     
    	std::queue<std::string> queue;
    	std::mutex mutex;
     
    	// Producer
    	std::thread producer([&]() {		
     
    		auto produce = [&](const char* message) {
                            std::stringstream stream;
    			stream << message;
    			auto element = stream.str();
     
    			mutex.lock();
    			std::cout << "Pushing " << message << std::endl;
    			queue.push(element);
    			mutex.unlock();
    		};
     
    		produce("hello, world");
    		produce("bye bye!");
    		produce(":)");
    	});
     
    	// Consumer
    	std::thread consumer([&]() {
    		while (true) {
    			if(not queue.empty()) {
    				auto message = queue.front();
    				std::cout << "Received = " << message << std::endl;
    				queue.pop();}
    		}
    	});
     
    	// Main
    	producer.join();
    	consumer.join();
    }
    Tu vois que les seules variables à créer dans le main sont la queue et le mutex. Toutes les autres devraient être à l'intérieur de tes threads.

    En écrivant ce code, je me suis rendu compte que tu ne faisais pas de pop() après avoir fait front(). Si je ne m'abuse, tu n'enlèves donc jamais les éléments de ta queue (voir http://en.cppreference.com/w/cpp/container/queue/front).


    CORRECTION : il manque une protection via mutex quand on accède à la queue dans 'consumer'. Le code devrait être ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    	std::thread consumer([&]() {
    		while (true) {
    			if(not queue.empty()) {
    				mutex.lock();
    				auto message = queue.front();
    				queue.pop();
    				mutex.unlock();
     
    				std::cout << "Received = " << message << std::endl;
    			}
    		}
    	});

  13. #13
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    Merci beaucoup je vais essayer avec ça. Mais ne faut il pas mettre un mutex dans le thread consumer?

  14. #14
    Expert éminent
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 565
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 565
    Points : 7 648
    Points
    7 648
    Par défaut
    Oui, il faut bien sûr protéger toutes les utilisations de queue.

  15. #15
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    J'ai pas encore très bien compris comment fonctionnait les queue. Est-ce que les char* reste entier dans la queue ou sont ils sépares en chars. Si j'entre "un groupe\n un autre groupe" je vais avec push récupérer le même objet ou récupérer seulement "un groupe"?

  16. #16
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 115
    Points : 32 967
    Points
    32 967
    Billets dans le blog
    4
    Par défaut
    Citation Envoyé par lilocratch Voir le message
    Est-ce que les char* reste entier dans la queue ou sont ils sépares en chars.

    Citation Envoyé par lilocratch Voir le message
    Si j'entre "un groupe\n un autre groupe" je vais avec push récupérer le même objet ou récupérer seulement "un groupe"?
    Pourquoi et par quelle magie aurais-tu quelque chose de différent ?! Tu ajoutes "nimporte quoi" dans la collection, tout ce qu'elle fait c'est garder ça en elle pour que tu puisses y accéder quand bon te semble..
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  17. #17
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    OK merci,
    je pensais que la queue prenait les elements du tableau et les poussait jusqu'a \n.

  18. #18
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Juin 2009
    Messages
    4 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 481
    Points : 13 679
    Points
    13 679
    Billets dans le blog
    1
    Par défaut
    Il manque effectivement un mutex lock/unlock lors qu'on souhaite récupérer des éléments de la queue, mea culpa !

    J'aurais dû faire ça comme lambda en fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    auto produce = [&](const std::string& message) { ... };
    En C++, on évite de jouer avec les const char* si on n'a pas de bonnes raisons.

    La queue ne sait rien d'un quelconque '\n'. C'est à toi de récupérer ton texte, de créer des std::strings et d'appeler produce() avec.

    Pour répondre à la question de ton message supprimé (oui, les modérateurs ont des pouvoirs de vision ), tu n'as pas à t'occuper du type de 'produce'. En fait, tu ne pourrais même pas l'écrire, seul le compilateur y arrive. C'est un des cas magiques de l'utilisation de 'auto'. Si tu veux vraiment tout savoir, on peut réussir à faire cracher le type complet au compilateur et ça donne ceci : 'main(int, char**)::<lambda()>::<lambda(const string&)>'. Comme tu vois, 'auto', c'est très bien

  19. #19
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2018
    Messages : 17
    Points : 5
    Points
    5
    Par défaut
    Merci à tous. J'ai réussit à faire mon programme et (pour l'instant) il marche correctement.

  20. #20
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Salut,

    @Bktero : Par contre, pourquoi protéger les accès à la file

    Parce que, en principe, c'est justement tout l'intérêt d'une file : on "push" à "back" et on "pop" à "top". Il n'y a donc théoriquement aucun risque de collision entre l'ajout et le retrait
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Lire avec fscanf dans un fichier avec délimiteurs
    Par Share45 dans le forum Débuter
    Réponses: 14
    Dernier message: 04/02/2016, 18h58
  2. Problème avec 2 threads : l'un bloque l'autre
    Par pontus21 dans le forum Linux
    Réponses: 13
    Dernier message: 17/01/2008, 13h09
  3. Des problemes avec ces threads <pthread.h>
    Par nasamad dans le forum GTK+ avec C & C++
    Réponses: 26
    Dernier message: 07/07/2006, 12h46
  4. [Threads] Actions continues avec des threads
    Par MiJack dans le forum Concurrence et multi-thread
    Réponses: 6
    Dernier message: 10/10/2005, 17h32
  5. [langage] Perl a t'il été compiler avec les threads
    Par vodevil dans le forum Langage
    Réponses: 2
    Dernier message: 07/05/2005, 15h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo