方法:柔性数组及其内存分配方式

1.代码示例

#include <stdio.h>
#include <string.h>

#define MAX_DATA_LEN 10

typedef struct  
{
	int len;
	unsigned char data[0];
}ArryType ,*ArrTypePtr;

int main()
{
	int i;
	ArryType *arr;
	ArryType arrb;

	//内存分配方式1
	char buf[sizeof(ArryType)+MAX_DATA_LEN] ={0};

	arr=(ArrTypePtr)buf;

	//内存分配方式2

	/*arr=(ArryType *)malloc(sizeof(int)+sizeof(unsigned char )*10);*/		

	for (i=0;i<10;i++)
	{
		arr->data[i]=i;
		printf("arr->data[%d]=%d\n",i,arr->data[i]);
	}


	printf("%d\n",sizeof(ArryType));

	return 0;

}

2.运行结果

arr->data[0]=0
arr->data[1]=1
arr->data[2]=2
arr->data[3]=3
arr->data[4]=4
arr->data[5]=5
arr->data[6]=6
arr->data[7]=7
arr->data[8]=8
arr->data[9]=9
4
请按任意键继续. . .
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weekman93

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值