目录
前言
结构体
格式
匿名结构体
结构体自引用
结构体初始化
结构体内存对齐
修改默认对齐数
位段
枚举
语法
联合体
语法
前言
最近在看视频学习c语言,作了一些笔记,发出来当作记录。视频链接:点击这里
结构体、位段、枚举、联合体是c语言中常见的自定义类型。
结构体成员不能是函数。
格式struct tag//标签,名字
{
member-list;//成员列表
}variable-list;//变量列表(全局对象列表)
示例
#include
typedef struct Stu
{
char name[10];
char sex[4];
int age;
}Stu;
int main
{
struct Stu s1;//定义对象
Stu s2;//typedef将sturct Stu类型重命名为Stu
return 0;
}
匿名结构体
没有名字的结构体,
示例:
struct
{
int a;
int b;
float c;
}x;
只能在变量列表中创建变量,如上面的x。
结构体自引用结构体成员不能是该结构体的对象,但可以是该结构体的指针。
示例,结构体实现链表:
struct Node//链表的一个节点结构体初始化
{
int data;//储存数据
struct Node* n;//指向下一个节点
};
需使用大括号,根据成员定义顺序,依次赋值。
示例:
#include
int main()
{
struct T
{
int a;
char b;
float c;
};
struct T f = {10, 'g', 3.4};
printf("%c\n",f.b); return 0;
}
>>g
结构体内存对齐
示例:
#include
struct T1
{
char a;//对齐数为1(字节)
int b;//对齐数为4
char c;//对齐数为1
};
struct T2
{
int a;//对齐数为4
char b;//对齐数为1
char c;//对齐数为1
};
struct T3
{
int a;//对齐数为4
struct T2 b;//对齐数为4
char c;//对齐数为1
}
int main()
{
struct T1 s1 = {0};
struct T2 s2 = { 0 };
struct T3 s3 = {0};
printf("%d\n", sizeof s1);
printf("%d\n", sizeof s2);
printf("%d\n", sizeof s3);
return 0;
}
>>12
>>8
>>16
gcc无默认对齐数。
设计结构体的原则:让占用空间小的成员尽量集中在一起以减少空间的浪费。
修改默认对齐数语法
#pragma pack(n)//将默认对齐数设置为n位段
#pragma pack()//取消设置的默认对齐数(设为1)
声明与结构体类似,有两个不同:
- 位段的成员必须是int、unsigned int 、或signed int。
- 位段的成员名后边有一个冒号和一个数字。
示例:
#include
struct S
{
int a:2;//占2个bits,不能大于32
int b:5;//占5个bits
int c:10;//占10个bits
}s1;
struct T
{
char a : 3;
char b : 4;
char c : 5;
char d : 4;
}t1;
int main()
{
printf("%d\n",sizeof s1);
printf("%d\n",sizeof t1);
return 0;
}
>>4
>>3
位段可用于互联网上数据包的声明。
枚举 语法enum tag//名字
{
//枚举的元素(均为常量)
};
枚举元素的取值默认从0开始,依次递增,可人为修改。
示例:
#include
enum DAY
{
Mon,
Tue,
Wed,
Thu,
Fri = 6, //将取值设置为6
Sat,
Sun
};
int main()
{
enum DAY s = Mon;
if (s == Mon)
{
printf("hh\n");
}
printf("%d %d %d %d %d %d %d\n", Mon, Tue, Wed, Thu, Fri, Sat, Sun);
printf("%d\n",sizeof s);//枚举类型占内存大小和整型相同
return 0;
}
>>hh
>>0 1 2 3 6 7 8
>>4
联合体
语法
union tag//名字
{
//成员变量
};
示例,判断计算机端序并求联合体所占内存大小:
#include
union T
{
char a;
int b;
char arr[5];//对齐数为1
} t;
int Check(union T t) //函数求计算机端序
{
t.a = 1;
return t.b;
};
int main()
{
printf("%d\n", sizeof t);
if (Check(t))
{
printf("小端序\n");
}
else
{
printf("大端序\n");
}
return 0;
}
>>8
>>小端序
大端字节序存储模式:数据的低位保存在内存中的高地址中,数据的高位保存在内存中的低地址中;
小端字节序存储模式:数据的低位保存在内存中的低地址中,数据的高位保存在内存中的高地址中;
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)