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

 C Discussion :

concatenation de 2 chaines


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juillet 2013
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 17
    Par défaut concatenation de 2 chaines
    Bonjour,
    voici mon probleme:
    j'ai 2 chaines de caracteres, une chaine qui a un nombre de caracteres fixes, et une chaine de caractere non fixe , et jaimerai les concatener pour que ma fonction sorte les 2.
    code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    void send()
    {
       TCHAR * pcCommande="BIBLI=";
       TCHAR * pcBibli=NULL;
       TCHAR * pcChaineConcate=NULL;
     
       printf("quelle est votre bibli? %s", pcCommande);
       scanf(%s, pcBibli);
       chaineConcat=strcat(puByte,pcCommande);
       printf(chaineConcat);
     
    }
    est ce quil faut utilise malloc?

  2. #2
    Membre Expert
    Avatar de Metalman
    Homme Profil pro
    Enseignant-Chercheur
    Inscrit en
    Juin 2005
    Messages
    1 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Enseignant-Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 049
    Par défaut
    Eh bah... il faut connaitre la taille max dans tous les cas avec scanf....

    Ou alors tu utilises "fread" sur "stdin", et tu reconstruis la chaîne au fur et à mesure avec strcat !

    PS : pense à la balise CODE ! (le petit # dans l'interface)
    --
    Metalman !

    Attendez 5 mins après mes posts... les EDIT vont vite avec moi...
    Les flags de la vie : gcc -W -Wall -Werror -ansi -pedantic mes_sources.c
    gcc -Wall -Wextra -Werror -std=c99 -pedantic mes_sources.c
    (ANSI retire quelques fonctions comme strdup...)
    L'outil de la vie : valgrind --show-reachable=yes --leak-check=full ./mon_programme
    Et s'assurer que la logique est bonne "aussi" !

    Ma page Developpez.net

  3. #3
    Membre chevronné
    Homme Profil pro
    Cadre informatique
    Inscrit en
    Avril 2013
    Messages
    183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Cadre informatique

    Informations forums :
    Inscription : Avril 2013
    Messages : 183
    Par défaut
    Citation Envoyé par rigole Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    void send()
    {
       TCHAR * pcCommande="BIBLI=";
       TCHAR * pcBibli=NULL;
       TCHAR * pcChaineConcate=NULL;
     
       printf("quelle est votre bibli? %s", pcCommande);
       scanf(%s, pcBibli);
       chaineConcat=strcat(puByte,pcCommande);
       printf(chaineConcat);
     
    }
    Bonjour,

    Juste comme ça, j'aurais quelques questions sur ton code?
    1*/ Tu initialises pcBibli à NULL mais tu lui enregistres une valeur avec le scanf (donc tu enregistres une valeur dans rien?), c'est normal?
    2*/ Ou est l'initialisation de chaineContact et puByte?

    Enfin je demande ça mais si tu as autre chose d'écrit et que tu l'as pas noté, je veux bien voir

    Merci

  4. #4
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Ton code est un mélange hybride de char et de TCHAR. Pourquoi avoid déclaré tes chaînes en TCHAR? Tu ne les utilises qu'avec des fonctions basées sur char...

    PS: Comme le dit Metalman, tu fais ton scanf() vers NULL, très mauvais.
    PPS: N'utilise pas le préfixe pc pour des pointeurs non-constants. Si tu me dis que c'est pour des pointeurs de char, c'est mauvais, d'une part on tombe dans la "systems hungarian notation", d'autre part tu si tu veux vraiment faire ça tu devrais utiliser psz à la place.
    PPPS: Pourquoi cette discussion est-elle marquée comme Résolue?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2009
    Messages
    4 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 493
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Médinoc
    c'est mauvais, d'une part on tombe dans la "systems hungarian notation"
    Tu n'aimes pas la notation hongroise ? ^^

    Citation Envoyé par Médinoc
    Comme le dit Metalman, tu fais ton scanf() vers NULL, très mauvais.
    Je dirai même plus, c'est très mauvais.

    Citation Envoyé par rigole
    j'ai 2 chaines de caracteres, une chaine qui a un nombre de caracteres fixes, et une chaine de caractere non fixe , et jaimerai les concatener pour que ma fonction sorte les 2.
    Non fixe mais forcément bornée ! Il y a une taille maximale que tu autorises pour cette chaine. Cette taille se donne normalement en allouant un espace avec malloc() mais toi, tu as mis NULL... Une fois cette borne (ou alors la taille utile, cad jusqu'à \0, ça dépend de ton utilisation) et la taille de la chaine fixe connues, il te suffit d'allouer (et oui, encore malloc()*) une nouvelle chaine de la bonne taille.

    Tu peux utiliser sprintf() si tu es en C99 pour connaitre la taille de la chaine résultante : http://stackoverflow.com/questions/3...s-the-standard
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    int size = snprintf(NULL, 0, "%d", 132);
    char * a = malloc(size + 1);
    sprintf(a, "%d", 132);
    * : en fait, tu pourrais aussi utiliser un VLA si tu es en C99.

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Tu n'aimes pas la notation hongroise ? ^^
    Si mais j'essaie (je n'y arrive pas toujours) d'utiliser plutôt la apps hungarian. (+préfixage des pointeurs, que je trouve indispensable dès qu'on touche à différents niveaux d'indirection/pointeurs de pointeurs).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Membre averti
    Inscrit en
    Juillet 2013
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 17
    Par défaut
    Citation Envoyé par Médinoc
    Pourquoi avoir déclaré tes chaînes en TCHAR?
    Parce que je travaille sur un projet et mon boss veut que ça soit comme ça!! ^^
    PS: Comme le dit Metalman, tu fais ton scanf() vers NULL, très mauvais.
    PPPS: Pourquoi cette discussion est-elle marquée comme Résolue?
    J'ai remodifié mon code et ça marche :

    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
    //TSerialStreamObject tSerialStream;
    TCONST TCHAR * pcCommandeAT="AT$SS=";
    TUCHAR * pucChaineConcat;
    void vFSend( TCONST TUCHAR * pucByte, TUCHAR ucSize )
    {
     //concaténation de commande AT$SS avant le mot à envoyer
     pucChaineConcat = strcat( ( TCHAR *)pcCommandeAT, ( TCONST TCHAR *)pucByte );
     
      // Taille de la chiane concaténée
     ucSize = strlen( pucChaineConcat );
     
     //Emission du message
     tSerialStream.uxFTxWrite( pucLigneComplete , ucSize );
     
    }
    avec la fonction uxFTxWrite(TUCHAR *, TUCHAR) que mon boss a écrit (transmission d'octet)
    Et du coup j'ai une autre question:
    je veux rajouter à la fin de ma chaine de caractères un carriage return <CR>
    mais ça me fais marche pas

  8. #8
    Membre chevronné
    Homme Profil pro
    Cadre informatique
    Inscrit en
    Avril 2013
    Messages
    183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Cadre informatique

    Informations forums :
    Inscription : Avril 2013
    Messages : 183
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    PS: Comme le dit Metalman, tu fais ton scanf() vers NULL, très mauvais.
    Metalman?

  9. #9
    Membre Expert
    Avatar de Metalman
    Homme Profil pro
    Enseignant-Chercheur
    Inscrit en
    Juin 2005
    Messages
    1 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Enseignant-Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 049
    Par défaut
    Ouais... j'ai pas osé intervenir (je vais pas salir mon grade, hein ! ), mais c'est Bysbobo qui a remonté le "NULL"...

    Moi j'ai juste dit que ça devait être une taille fixe qui reçoit les chars du scanf !

    Bravo Bysbobo du coup !
    --
    Metalman !

    Attendez 5 mins après mes posts... les EDIT vont vite avec moi...
    Les flags de la vie : gcc -W -Wall -Werror -ansi -pedantic mes_sources.c
    gcc -Wall -Wextra -Werror -std=c99 -pedantic mes_sources.c
    (ANSI retire quelques fonctions comme strdup...)
    L'outil de la vie : valgrind --show-reachable=yes --leak-check=full ./mon_programme
    Et s'assurer que la logique est bonne "aussi" !

    Ma page Developpez.net

  10. #10
    Membre régulier
    Inscrit en
    Juin 2013
    Messages
    7
    Détails du profil
    Informations forums :
    Inscription : Juin 2013
    Messages : 7
    Par défaut
    Bjr!!
    Est ce qu'on peut utiliser sprintf pour concater 3 chaines a la fois?
    ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    int main()
    {
      char * buffer[80];
      char * s1="hello";
      char * s2;
      char * s3="bye";
      printf("votre message?");
      scanf(%s, &s2);
      sprintf(buffer, "%s", s1, s3 );
    }
    ou quelque chose dans ce genre?
    Merci!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Concatener dynamiquement une chaine de caractères
    Par jcpreaux76 dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 13/02/2013, 15h07
  2. Concatener caractere et chaine de caracteres
    Par Flo90 dans le forum Débuter
    Réponses: 5
    Dernier message: 26/04/2010, 14h37
  3. concatener bind et chaine tiers
    Par mapmip dans le forum ASP.NET
    Réponses: 6
    Dernier message: 20/03/2008, 15h32
  4. Réponses: 6
    Dernier message: 13/11/2007, 12h33
  5. [debutant] Concatenation d'une chaine (string) et d'entiers
    Par websurfeur dans le forum Débuter
    Réponses: 2
    Dernier message: 26/03/2006, 11h05

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