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

Langage C++ Discussion :

Alignement mémoire - Taille totale d'une structure multiple de l'alignement de la structure


Sujet :

Langage C++

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 60
    Points : 36
    Points
    36
    Par défaut Alignement mémoire - Taille totale d'une structure multiple de l'alignement de la structure
    Bonsoir,

    je comprends pourquoi je dois prendre un alignement mémoire pour une structure égal à la taille la plus grande parmi ses attributs.

    Maintenant, j'aimerais savoir pourquoi, une fois cet alignement choisi, je dois faire du padding de telle manière que la taille totale de la structure soit un multiple de l'alignement de cette structure et non pas multiple de la taille d'un "mot proceseur".

    Voici un exemple :

    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
        #include <stdio.h>
     
        // Alignment requirements
        // (typical 32 bit machine)
     
        // char         1 byte
        // short int    2 bytes
        // int          4 bytes
        // double       8 bytes
     
        typedef struct structc_tag
        {
           char        c;
           double      d;
           int         s;
        } structc_t;
     
        int main()
        {
           printf("sizeof(structc_t) = %d\n", sizeof(structc_t));
     
           return 0;
        }
    On pourrait penser à priori que la taille de structc_t est égal à 20 avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
           char        c;
           char Padding1[7]
           double      d;
           int         s;
    parce que nous avons pris un alignement de structure égal à 8 (double d).

    En fait, la taille totale est égale à 24 parce que 20 n'est pas un multiple de 8 et nous devons faire du padding après "int s" ( char Padding2[4] ).

    Mais si je prends un tableau de cette structure (sans ajouter le deuxième padding Padding2[4]), les premiers éléments de chaque structure seront à des bonnes adresses pour un processeur 32 bits ( 0, 20, 40 ...) parce que 0, 20, 40 sont des multiples de 4, où 4 est la taille d'un "mot processeur" 32 bits.

    Donc, Pourquoi je dois faire ce deuxième padding pour avoir une taille totale multiple de 8 (taille de l'alignement de la structure), c'est-à-dire 24 ici dans cet exemple alors qu'on pourrait se contenter de n'avoir qu'une taille totale de 20 (tout en étant ainsi multiple de 4 et ainsi avoir un tableau de structc_t contigu en mémoire par rapport à un processeur 32 bits) ?

    Merci pour votre aide

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 072
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 072
    Points : 12 118
    Points
    12 118
    Par défaut
    Faites le calcul de l'alignement du champ "d" du 2ème élément d'un tableau de structc_t.

    Avec l'approche du compilateur, il sera sur sa frontière "naturelle" (8).

    Avec votre approche, il ne sera pas aligné sur sa frontière "naturelle" (8) mais sur 4 et demandera plus de décodage sur les plateformes souples et puissantes et carrément une erreur sur les machines rustres.

    Ceci n'est qu'un comportement par défaut qui donne une solution correct même si on conçoit ses structures à l'arrache. Mais il est tout à fait possible de changer ces réglages à coup de "#pragma pack" et consort si on sait ce que l'on fait.

Discussions similaires

  1. Taille Totale d'une DB MySQL 4
    Par ouranos21 dans le forum Administration
    Réponses: 2
    Dernier message: 11/07/2008, 15h53
  2. Alignement mémoire pour les structures.
    Par SpaceToto dans le forum Visual C++
    Réponses: 4
    Dernier message: 14/09/2006, 11h15
  3. Taille totale de la mémoire vidéo
    Par nicolas66 dans le forum Windows
    Réponses: 13
    Dernier message: 26/07/2006, 16h33
  4. récupérer la taille totale d'une image avant chargement
    Par sorenson dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 25/06/2006, 14h50

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