椋鸟C语言笔记#31

结构体(联合体)嵌套、柔性数组

Featured image

萌新的学习笔记,写错了恳请斧正。

结构体(联合体)嵌套

结构体、联合体可以嵌套,也就是说结构体(联合体)的成员也可以是结构体(联合体)

嵌套时内嵌结构体(联合体)不创建变量(匿名)

如果嵌套时内嵌结构体(联合体)不创建变量(匿名),内嵌结构体(联合体)的成员会被认为是外围结构体(联合体)的成员,如果外围结构体(联合体)也是匿名的,那么就递归应用此规则:

#include <stdio.h>

struct
{
	int x;
	struct
	{
		int y;
		union
		{
			int z;
			char c;
		};
	};
} a;


int main()
{
	a.z = 1;
	printf("%d\n", a.c);
	return 0;
}

注意:此匿名非彼匿名,结构体类型依旧可以有名字,但是不能内嵌结构体只能有其声明部分而不能在后面加成员变量名

嵌套时内嵌结构体(联合体)创建变量(非匿名)

当嵌套时内嵌结构体(联合体)创建变量(非匿名),则需要通过访问操作符先访问这个内嵌结构体类型的成员,再访问其中的成员,如果外围结构体(联合体)也是非匿名结构体,那么就递归应用此规则:

#include <stdio.h>


struct S1
{
	struct S2
	{
		union U1
		{
			union U2
			{
				int n1;
				int n2;
			} u2;
			int n3;
		} u1;
		int n4;
	} s2;
	int n5;
} s1;

int main()
{
	s1.s2.u1.u2.n1 = 1;
	printf("%d\n", s1.s2.u1.n3);
	return 0;
}

同样的,这里的非匿名也与匿名结构体无关,结构体类型也可以没有命名,但是内嵌结构体后面应该加成员变量名

嵌套初始化

这边 C 官网上讲的足够清楚了,链接在此

柔性数组

在 C99 标准以后,结构体的最后一个成员被允许是一个未知大小的数组,这就叫柔性数组

这个未知大小当然不是真的未知,而是 “可动态分配”

比方说:

struct S
{
	int i;
	long arr[];
};

或者写成:

struct S
{
	int i;
	long arr[0];
};

特点:

柔性数组的使用

如下便是给柔性数组分配了 40 个长整型的空间

#include <stdio.h>
#include <stdlib.h>

typedef struct
{
	int i;
	long arr[];
} stt;

int main()
{
	stt* p = (stt*)malloc(sizeof(stt) + 40 * sizeof(long));
	if (p == NULL)
	{
		perror("malloc-p");
		exit(EXIT_FAILURE);
	}

	p->i = 40;
	for (int i = 0; i < 40; i++)
		p->arr[i] = i + 1;
	for (int i = 0; i < 40; i++)
		printf("%2ld\t", (*p).arr[i]);

	free(p);
	p = NULL;
	return 0;
}