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 :

sizeof portable ?


Sujet :

C

  1. #1
    Membre confirmé Avatar de Array
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    210
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 210
    Par défaut sizeof portable ?
    Bonjour,

    Voici un code impliquant l'opérateur sizeof:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    #include <stdio.h>
     
    int main(void) {
            printf("%d", sizeof (int));
            return 0;
    }
    Je le compile sur une machine ayant les int codés sur 32 bits (chars en 8 bits).

    Si je l'utilise cet exécutable sur une machine ayant les int codés sur 16 bits (chars en 8 bits), est-ce que le programme écrirait "2" ou "4"?

    Autrement dit, est-ce que sizeof est portable ou le résultat dépend-t-il seulement de la machine sur laquelle le programme a été compilé?

    Merci,

    Array

  2. #2
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    Septembre 2007
    Messages
    7 511
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur d'emploi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 511
    Par défaut
    Citation Envoyé par Array Voir le message
    Autrement dit, est-ce que sizeof est portable ou le résultat dépend-t-il seulement de la machine sur laquelle le programme a été compilé ?
    Les deux.

    Effectivement, la valeur de sizeof() va dépendre de la machine sur laquelle tu vas compiler ton programme. Maintenant, sizeof() est portable en soi, puisque c'est un mot-clé du C et que sa principale utilité est justement l'examen des différences de taille.

  3. #3
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Array Voir le message
    Voici un code impliquant l'opérateur sizeof:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    #include <stdio.h>
     
    int main(void) {
            printf("%d", sizeof (int));
            return 0;
    }
    Je le compile sur une machine ayant les int codés sur 32 bits (chars en 8 bits).

    Si je l'utilise cet exécutable sur une machine ayant les int codés sur 16 bits (chars en 8 bits), est-ce que le programme écrirait "2" ou "4"?

    Autrement dit, est-ce que sizeof est portable ou le résultat dépend-t-il seulement de la machine sur laquelle le programme a été compilé?
    Cette question n'a pas de sens.

    1 - sizeof est un opérateur. (il n'y a donc pas de parenthèses).
    2 - la définition de cette opérateur est "retourne la taille d'un objet ou d'un (type) en nombre de char. Cette valeur est de type size_t."
    3 - la notion de 'portabilité' n'a rien à voir avec cet opérateur.
    4 - la taille des objets et des (types) peut changer d'une machine à l'autre, d'un système à l'autre, d'une option de compilation à l'autre etc. sizeof n'a rien à voir avec ça.

  4. #4
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    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 398
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    1 - sizeof est un opérateur. (il n'y a donc pas de parenthèses).
    Il me semblait avoir lu sur ce forum même que contrairement à sizeof variable, sizeof(type) nécessitait les parenthèses?

    @Array: La valeur retourné par sizeof dépend de l'architecture pour laquelle le programme a été compilé, indépendamment de l'architecture sur laquelle il l'est.

    En clair, si tu compiles sur un x86 32 bits mais pour une architecture 64 bits ILP64, sizeof(int) vaudra toujours 8 et le programme ne s'exécutera que sur l'architecture en question.

    Pareil, si tu compiles un programme pour DOS (16 bits), sizeof(int) vaudra toujours 2. Si tu l'exécutes sous WinNT (32 bits), le programme tournera en fait sur une architecture 16 bits émulée (la Virtual DOS Machine, NTVDM.exe).
    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
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Il me semblait avoir lu sur ce forum même que contrairement à sizeof variable, sizeof(type) nécessitait les parenthèses?
    Les () appartiennent au type (comme un cast), pas à sizeof.

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    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 398
    Par défaut
    Je ne comprends pas ce que tu veux dire, là.
    Sous Visual et MinGW en tout cas, sizeof char plante.
    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
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Je ne comprends pas ce que tu veux dire, là.
    Sous Visual et MinGW en tout cas, sizeof char plante.
    Mais pas sizeof (char). Comme pour un cast, on doit mettre des parenthèses autour du type.

  8. #8
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    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 398
    Par défaut
    Donc, sizeof demande une expression possédant un type, même si elle n'a pas de valeur?
    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
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    L'expression suivant un sizeof n'est pas évaluée (sauf dans le cas des VLA), seul le type de l'expression est déterminé.

  10. #10
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    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 398
    Par défaut
    Oui, mais elle est quand même compilée.
    Et chez moi, cette expression ne compile pas s'il n'y a pas sizeof devant:
    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.

  11. #11
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Oui, mais elle est quand même compilée.
    Et chez moi, cette expression ne compile pas s'il n'y a pas sizeof devant:
    Code C :
    Oui elle est compilée et la valeur de sizeof .... est déterminée à la compilation (sauf pour les VLA).
    Chez moi non plus l'expression que tu cites ne compile pas. Quel pourrait être son sens ?

    Ce que dit Emmanuel, et il suit le point de vue de la norme en cela, c'est que sizeof s'applique à une expression ou à un type placé entre parenthèses. Les parenthèses n'appartiennent pas à l'opérateur sizeof mais à son opérande.
    Ce qui rend l'opérande syntaxiquement analogue à l'opérateur de cast.

    De la même façon, si on place l'expression entre parenthèses, ces parenthèses appartiennent à l'expression ce qui rend le tout conforme à la syntaxe sizeof expression

  12. #12
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    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 398
    Par défaut
    En fait, la grammaire ANSI C dit ceci:
    Code yacc : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    unary_expression
    	: postfix_expression
    	| INC_OP unary_expression
    	| DEC_OP unary_expression
    	| unary_operator cast_expression
    	| SIZEOF unary_expression
    	| SIZEOF '(' type_name ')'
    	;
    Les parenthèses font donc bien partie intégrante de sizeof (type), même si elles ne sont pas nécessairement accolées à l'opérateur.
    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.

  13. #13
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    n1256 dit clairement
    6.5.3.4 The sizeof operator
    ....
    2 The sizeof operator yields the size (in bytes) of its operand, which may be an expression or the parenthesized name of a type.

  14. #14
    Membre éclairé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Août 2007
    Messages
    509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Août 2007
    Messages : 509
    Par défaut
    A mon avis, vous avez tous 2 raison

Discussions similaires

  1. Application Portable sur differents types de BDD
    Par sylvain_2020 dans le forum Décisions SGBD
    Réponses: 11
    Dernier message: 23/09/2003, 13h59
  2. Comment faire un Timer de fonction PORTABLE ?
    Par dieuP1guin dans le forum C
    Réponses: 3
    Dernier message: 04/07/2003, 11h44
  3. Code Portable
    Par D[r]eadLock dans le forum C
    Réponses: 9
    Dernier message: 14/09/2002, 14h44
  4. [Migratation] Application portable, indépendant du SGDB
    Par benouille dans le forum Décisions SGBD
    Réponses: 6
    Dernier message: 28/08/2002, 14h51
  5. Choix d'un EDI pour la 3D (Open GL, Portable)
    Par Riko dans le forum OpenGL
    Réponses: 6
    Dernier message: 01/08/2002, 13h25

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