zoukankan      html  css  js  c++  java
  • 内存对齐的三条原则

    1:数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员大小或者成员的子成员大小(只要该成员有子成员,比如说是数组,结构体等)的整数倍开始(比如int在32位机为4字节,则要从4的整数倍地址开始存储。
     
    2:结构体作为成员:如果一个结构里有某些结构体成员,则结构体成员要从其内部最大元素大小的整数倍地址开始存储.(struct a里存有struct b,b里有char,int ,double等元素,那b应该从8的整数倍开始存储.)
     
    3:收尾工作:结构体的总大小,也就是sizeof的结果,.必须是其内部最大成员的整数倍.不足的要补齐。
     
     
     
     1 typedef struct bb
     2 {
     3  int id;             //[0]....[3]
     4  double weight;      //[8].....[15]      原则1
     5  float height;      //[16]..[19],总长要为8的整数倍,补齐[20]...[23]     原则3
     6 }BB;
     7 typedef struct aa
     8 {
     9  char name[2];     //[0],[1]
    10  int  id;         //[4]...[7]          原则1
    11  double score;     //[8]....[15]    
    12  short grade;    //[16],[17]        
    13  BB b;             //[24]......[47]          原则2
    14 }AA;
    15 int main()
    16 {
    17   AA a;
    18   cout<<sizeof(a)<<" "<<sizeof(BB)<<endl;
    19   return 0;
    20 }
    结果是
    48 24

  • 相关阅读:
    详解 Android Activity 生命周期
    设计模式:装饰者模式
    析构函数virtual与非virtual区别 [转]
    详解 常量指针和指针常量
    [转]Python yield 使用浅析
    python 列表 总结
    [转]关于Python中的yield
    详解c++指针的指针和指针的引用
    转:Ogre源码剖析
    转:Ogre源码剖析1
  • 原文地址:https://www.cnblogs.com/linhaostudy/p/7715667.html
Copyright © 2011-2022 走看看