解析C语言结构体及位段

 更新时间:2018年12月19日 09:57:11   作者:胡小哲  
今天小编就为大家分享一篇关于解析C语言结构体及位段,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

1.结构的定义

在实际情况中,数据经常以成组的形式存在。如果这些值的类型各不相同,他们无法同时存储于同一个数组中,在C中,可以使用结构把不同类型的值存储在一起,所以结构也是一些值的集合,这些值称为它的成员,但是这些成员的类型可以不同。

拓展:

“结构”是一种构造数据类型,也叫做用户自定义数据类型,它是由若干“成员”组成的。 每一个成员可以是一个基本数据类型或者又是一个构造类型。 结构即是一种“构造”而成的数据类型, 那么在说明和使用之前必须先定义它,也就是构造它。如同在说明和调用函数之前要先定义一样。

2.结构的初始化

结构的初始化和数组相似,位于一对花括号内,由逗号分隔初始值,可用于结构各个成员的初始化。这些值将根据结构成员的顺序写出,如果初始值不够,剩余的结构成员将使用缺省值进行初始化。

struct S
{
  int a;
  int b[10];
  char c[20];
}s={
    10,
    {1,2,3,4,5},
    "abc"
  };

typedef:在C中,定义一个结构体类型如果要用typedef:

typedef struct Student
{
  int a;
}Stu;

当需要声明变量时,就可以直接Stu.stu1;如果没有typedef则需用 struct Student stu1 来声明;(Stu==struct Student);

4.结构体的内存存储

结构在内存中的存储是按照成员列表顺序一个接一个的给每个成员分配内存。而在分配的时候则遵循结构体内存对齐规则:

  • (1).第一个成员在与结构体变量偏移量为0的地址处;
  • (2).其他成员变量要对齐到对齐数的整数倍的地址处; 对齐数:编译器的默认对齐数与该成员大小的较小值; (默认对齐数 vs:8,linux:4)
  • (3).结构体的总大小为最大对齐数的整数倍。
  • (4).如果嵌套了结构体的情况,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整体大小就是所有最大对齐数的整数倍。
struct S
{
  int a;
  char b;
  double c;
};
//则此结构体大小为16
stuct A
{
  doulbe d;
  char e;
};
struct S
{
  int a;
  char b;
  struct A C;
  double c;
};
//结构体S的大小为32

内存对齐的原因:

  • (1).平台原因:不是所有的硬件平台都能访问任意地址上的任意数据;某些硬件平台只能在某些地址处取某些特定类型的数据,否则将抛出硬件异常。
  • (2).性能原因:数据结构应该尽可能的在自然边界上对齐。原因在于,为了访问未对齐的内存,处理器需要作两次内存访问,而对齐的内存访问仅需要一次访问。

5.结构体位段

位段的声明和结构类似,但位段的成员是一个或多个位的字段。位段成员必须声明位int,unsigned int或signed int类型。在成员的后面是一个冒号和一个整数,这个整数就是该位段所占用的位的大小。

struct S
{
  int a : 7;
  signed int b : 6;
  unsigned int c : 12;
};

位段的数据存储:

当一个声明指定了2个位段,第二个位段无法放在第一个位段剩余的位上,编译器有可能把第二个位段放在内存的下一个字节上,也可能直接放在第一个位段后面。

位段的大小:

位段的大小取决于编辑器对位段的数据存储:

struct S
{
  int a : 1;
};
//S的大小为4
struct S
{
  int a : 1;
  int b : 5;
  int c : 6;
};

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • 基于一致性hash算法 C++语言的实现详解

    基于一致性hash算法 C++语言的实现详解

    在《基于一致性hash算法(consistent hashing)的使用详解》一文中已经介绍了一致性hash的基本原理,本文将会对其具体实现细节进行描述,并用c++语言对一致性hash进行了简单的实现
    2013-05-05
  • C++ Date类的具体使用(构建,重载等)

    C++ Date类的具体使用(构建,重载等)

    本文主要介绍了C++ Date类的具体使用(构建,重载等),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • C++ 类中有虚函数(虚函数表)时 内存分布详解

    C++ 类中有虚函数(虚函数表)时 内存分布详解

    下面小编就为大家带来一篇C++ 类中有虚函数(虚函数表)时 内存分布详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • OpenCV图像文件批量读取编程实例

    OpenCV图像文件批量读取编程实例

    这篇文章主要为大家详细介绍了OpenCV图像文件批量读取编程实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • 如何用C写一个web服务器之基础功能

    如何用C写一个web服务器之基础功能

    C语言是一门很基础的语言,程序员们对它推崇备至,本文将带着大家来看一下,如何用C写一个web服务器。
    2021-05-05
  • 全面了解C语言 static 关键字

    全面了解C语言 static 关键字

    这篇文章主要介绍了全面了解C语言 static 关键字,文章首先通过先介绍一下头文件的创建展开主题的详细内容,需要的小伙伴可以参考一下
    2022-04-04
  • C++ opencv图像平滑滤波器使用示例

    C++ opencv图像平滑滤波器使用示例

    这篇文章主要为大家介绍了C++ opencv数字图像处理图像平滑滤波器的使用示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • C++中常见容器类的使用方法详解(vector/deque/map/set)

    C++中常见容器类的使用方法详解(vector/deque/map/set)

    C++中常见的容器类有vector、list、deque、map、set、unordered_map和unordered_set。下面将举例直接说明各个容器的使用方法,希望对大家有所帮助
    2023-03-03
  • C++数据结构之红黑树的实现

    C++数据结构之红黑树的实现

    红黑树在表意上就是一棵每个节点带有颜色的二叉搜索树,并通过对节点颜色的控制,使该二叉搜索树达到尽量平衡的状态。本文主要为大家介绍了C++中红黑树的原理及实现,需要的可以参考一下
    2022-08-08
  • C++超详细分析红黑树

    C++超详细分析红黑树

    这一篇我要跟大家介绍二叉搜索树中的另一颗树——红黑树,它主要是通过控制颜色来控制自身的平衡,但它的平衡没有AVL树的平衡那么严格
    2022-03-03

最新评论