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 :

lecture d'un tableau uint8_t avec sscanf


Sujet :

C

  1. #1
    Membre du Club
    Inscrit en
    Janvier 2005
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 100
    Points : 49
    Points
    49
    Par défaut lecture d'un tableau uint8_t avec sscanf
    Bonjour
    j'ai besoin de convertir une chaine de caractere
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    char* buffer = "000102030405060708090A0B0C0D0E0F";
    en un tableau
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    uint8_t tab[16] = {0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 
    0xa, 0xb, 0xc, 0xd, 0xe, 0xf}
    J'ai essaye avec sscanf ca a marche mais ca donne les warnings
    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
     
    #include <stdio.h>
     
    #include <stdlib.h>
    #include <stdint.h>
     
    #define BUFFER_FORMAT "%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
     
    #define MAX_ELEMENTS 16
     
    int main (void)
     
    {
    char *buffer = "000102030405060708090A0B0C0D0E0F";
    uint8_t tab[MAX_ELEMENTS];
    int i;
     
     
     
    sscanf(buffer,BUFFER_FORMAT,tab, tab+1, tab+2, tab+3, tab+4, 
             tab+5 ,tab+6, tab +7, tab +8 , tab +9, tab + 10 , tab + 11, 
             tab + 12,tab + 13,tab +14, tab + 15);
     
    for (  i=0; i < MAX_ELEMENTS; i++)
    {
        printf ("tab[%d] = %02x\n", i , tab[i]);
     
    }
     
    return 0 ;
     
    }
    gcc -Wall -g sscanf1.c -o sscanf1
    sscanf1.c: In function ‘main’:
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 3 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 4 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 5 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 6 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 7 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 8 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 9 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 10 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 11 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 12 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 13 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 14 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 15 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 16 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 17 has type ‘uint8_t *’
    sscanf1.c:21: warning: format ‘%02x’ expects type ‘unsigned int *’, but argument 18 has type ‘uint8_t *’


    Ya t il un moyen d'eliminer ces warnings ?

    A l'execution la conversion se fait normalement mais j'ai une erreur
    *** stack smashing detected ***: ./sscanf1 terminated
    Aborted (core dumped)

    tab[0] = 00
    tab[1] = 01
    tab[2] = 02
    tab[3] = 03
    tab[4] = 04
    tab[5] = 05
    tab[6] = 06
    tab[7] = 07
    tab[8] = 08
    tab[9] = 09
    tab[10] = 0a
    tab[11] = 0b
    tab[12] = 0c
    tab[13] = 0d
    tab[14] = 0e
    tab[15] = 0f
    *** stack smashing detected ***: ./sscanf1 terminated
    Aborted (core dumped)

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Essaie de voir s'il n'y a pas un format pour unsigned char, du genre "%02hhx"...
    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.

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Alors, résultat du test: Apparemment, "%hhu" est bien censé représenter un unsigned char (gcc ne donne pas de warning de format), mais l'implémentation Micro$oft MSVCRT.DLL s'a$$eoit dessus et retourne un int quand même (alors que "%hu" marche correctement pour un unsigned short), y compris pour des versions récentes de Visual comme la 2005.

    Edit: Le spécificateur hh est exigé par la norme C99, que Micro$oft a fait le choix de ne pas respecter. Par contre, j'ignore ce qu'il en est dans la norme C90...
    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.

  4. #4
    Membre émérite Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Points : 2 280
    Points
    2 280
    Par défaut
    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
    #if  __STDC_VERSION__ < 199901L
    #error you need a C99 compliant compiler
    #endif
     
    #include <stdio.h> 
    #include <stdint.h>
    #include <inttypes.h>
     
    #define FORMAT "%2"SCNx8
    #define BUFFER_FORMAT  FORMAT FORMAT FORMAT FORMAT \
                           FORMAT FORMAT FORMAT FORMAT \
                           FORMAT FORMAT FORMAT FORMAT \
                           FORMAT FORMAT FORMAT FORMAT
     
    #define MAX_ELEMENTS (sizeof BUFFER_FORMAT - 1) / (sizeof FORMAT -1)
     
    int main (void)
    {
       char const *buffer = "000102030405060708090A0B0C0D0E0F";
       uint8_t tab[MAX_ELEMENTS];
     
       sscanf (buffer, BUFFER_FORMAT,tab, tab+1, tab+2, tab+3, tab+4, 
               tab+5, tab+6, tab+7, tab+8, tab+9, tab+10, tab+11, 
               tab+12, tab+13, tab+14, tab+15);
     
       for (size_t i = 0; i < MAX_ELEMENTS; i++)
       {
           printf ("tab[%zu] = %#" PRIx8 "\n", i, tab[i]); 
       }
     
       return 0 ; 
    }
    Cordialement.
    "The quieter you become, the more you are able to hear"
    "Plus vous êtes silencieux, plus vous êtes capable d'entendre"

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Le problème, c'est que ce code compilera sous MinGW en mode C99, mais c'est quand même MSVCRT.DLL qui sera utilisée...

    PS: Quelqu'un a-t-il la norme C90 à portée de main pour qu'on sache si elle exige le hh ou non?
    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.

  6. #6
    Membre émérite Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Points : 2 280
    Points
    2 280
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Le problème, c'est que ce code compilera sous MinGW en mode C99, mais c'est quand même MSVCRT.DLL qui sera utilisée...
    J'imagine que le PO utilise un compilateur et une bibliothèque C99.

    Citation Envoyé par Médinoc Voir le message
    PS: Quelqu'un a-t-il la norme C90 à portée de main pour qu'on sache si elle exige le hh ou non?
    Je viens de vérifier, nulle part il n'y est fait mention d'un spécificateur de conversion hh.
    "The quieter you become, the more you are able to hear"
    "Plus vous êtes silencieux, plus vous êtes capable d'entendre"

  7. #7
    Membre du Club
    Inscrit en
    Janvier 2005
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    le modificateur hh existe bien sous linux
    hh
    Specifies that a following d , i , o , u , x , X , or n conversion specifier applies to an argument with type pointer to signed char or unsigned char.
    http://www.linuxcertif.com/man/3/scanf/
    http://xrenault.developpez.com/tutoriels/c/scanf/
    http://linux.die.net/man/3/scanf

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    hh apparait aussi dans la norme POSIX ((l'historique en fin de page est particulièrement intéressant).
    Par contre, il n'apparait donc pas dans la norme C90, il ne faut donc pas l'utiliser sous Windows (la CRT Microsoft étant compatible C90 mais pas POSIX ni C99).
    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.

  9. #9
    Membre émérite Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Points : 2 280
    Points
    2 280
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    il ne faut donc pas l'utiliser sous Windows (la CRT Microsoft étant compatible C90 mais pas POSIX ni C99).
    Seulement pour ceux utilisant la CRT Microsoft biensûr, car il existe d'autre CRT, celle de Dinkumware par exemple : 100% C99 compliant.
    "The quieter you become, the more you are able to hear"
    "Plus vous êtes silencieux, plus vous êtes capable d'entendre"

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

Discussions similaires

  1. Lecture d'un double avec sscanf
    Par kiwi2mars dans le forum Débuter
    Réponses: 5
    Dernier message: 09/08/2013, 09h59
  2. [win32com][Excel] Lecture d'un tableau excel avec plusieurs coeurs
    Par sir_nebuchadnezzar dans le forum Bibliothèques tierces
    Réponses: 7
    Dernier message: 26/07/2012, 17h01
  3. Réponses: 4
    Dernier message: 12/10/2005, 21h22
  4. Réponses: 2
    Dernier message: 13/12/2004, 23h32
  5. [VB6] recuperer des valeurs ds un tableau html avec vb!!
    Par leo13 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 11/12/2004, 13h02

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