下面这个结构体,可以在malloc的时候指定数据data的长度,这样的形式就是变长数组
typedef struct
{
  int data_len;
  char data[0];//或char data[];
}buff_st_a;

用法:在下面的例子中,
buff_st_b和buff_st_a用法相同,用数组名来表示数据地址,这时数据是紧挨着p_struct的,这样p_struct和p_data不用各自分开分配和释放,使用起来很方便;
buff_st_p用指针来存储数据地址,这时数据的地址并不是紧挨着p_struct的,p_struct和p_data必须各自分开分配和释放;

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h> typedef struct
{
int data_len;
char data[0];
}buff_st_a; typedef struct
{
int data_len;
char data[];
}buff_st_b; typedef struct
{
int data_len;
char *data;
}buff_st_p; typedef struct
{
uint32_t id;
uint32_t age;
}data_st; void show_data(const data_st *data)
{
printf("data:\n id :%u,age :%u\n\n", data->id, data->age);
}
void show_addr(char* type, void* p_buf)
{
  printf("for %s,\naddress:\n ", type);   if(0 == strcmp(type, "buff_st_a")){
    buff_st_a *pbuf = (buff_st_a*)p_buf;
    printf("pbuf :%p\t,pbuf->data_len :%p\t,pbuf->data :%p\t\n",
pbuf, &(pbuf->data_len), pbuf->data);
  }else if(0 == strcmp(type, "buff_st_b")){
    buff_st_b *pbuf = (buff_st_b*)p_buf;
    printf("pbuf :%p\t,pbuf->data_len :%p\t,pbuf->data :%p\t\n",
pbuf, &(pbuf->data_len), pbuf->data);
  }else if(0 == strcmp(type, "buff_st_p")){
    buff_st_p *pbuf = (buff_st_p*)p_buf;
    printf("pbuf :%p\t,pbuf->data_len :%p\t,pbuf->data :%p\t\n",
pbuf, &(pbuf->data_len), pbuf->data);
} } int useage()
{
data_st *data = (data_st *)malloc(sizeof(data_st));
data->id = 100;
data->age = 23; buff_st_a *buffa = (buff_st_a *)malloc(sizeof(buff_st_a) + sizeof(data_st));
buffa->data_len = sizeof(data_st);
memcpy(buffa->data, data, buffa->data_len);
show_addr("buff_st_a", buffa);
show_data((data_st*)buffa->data); buff_st_b *buffb = (buff_st_b *)malloc(sizeof(buff_st_b) + sizeof(data_st));
buffb->data_len = sizeof(data_st);
memcpy(buffb->data, data, buffb->data_len);
show_addr("buff_st_b", buffb);
show_data((data_st*)buffb->data); buff_st_p *buffp = (buff_st_p *)malloc(sizeof(buff_st_p));
buffp->data_len = sizeof(data_st);
buffp->data = (char *)malloc(buffp->data_len);
memcpy(buffp->data, data, buffp->data_len);
show_addr("buff_st_p", buffp);
show_data((data_st*)buffp->data); free(buffa); free(buffb); free(buffp->data);
free(buffp); free(data);
return 0;
} int main()
{
useage();
return 0;
}

  

/*
for buff_st_a,
address:
pbuf :0x892f018 ,pbuf->data_len :0x892f018 ,pbuf->data :0x892f01c
data:
id :100,age :23

for buff_st_b,
address:
pbuf :0x892f028 ,pbuf->data_len :0x892f028 ,pbuf->data :0x892f02c
data:
id :100,age :23

for buff_st_p,
address:
pbuf :0x892f038 ,pbuf->data_len :0x892f038 ,pbuf->data :0x892f048
data:
  id :100,age :23

*/

C语言变长数组data[0]【总结】

char data[0]用法总结

c语言,变长数组的更多相关文章

  1. C语言变长数组 struct中char data[0]的用法

    版权声明:本文为博主原创文章,未经博主允许不得转载. 今天在看一段代码时出现了用结构体实现变长数组的写法,一开始因为忘记了这种技术,所以老觉得作者的源码有误,最后经过我深思之后,终于想起以前看过的用s ...

  2. C语言变长数组data[0]总结

    C语言变长数组data[0] 1.前言 今天在看代码中遇到一个结构中包含char data[0],第一次见到时感觉很奇怪,数组的长度怎么可以为零呢?于是上网搜索一下这样的用法的目的,发现在linux内 ...

  3. C语言变长数组data[0]

    1.前言 在刷题时遇到一个结构中包含char data[0],第一次见到时感觉很奇怪,数组的长度怎么可以为零呢?于是上网搜索一下这样的用法的目的,发现在linux内核中,结构体中经常用到data[0] ...

  4. C语言变长数组data[0]【总结】

    1.前言 今天在看代码中遇到一个结构中包含char data[0],第一次见到时感觉很奇怪,数组的长度怎么可以为零呢?于是上网搜索一下这样的用法的目的,发现在linux内核中,结构体中经常用到data ...

  5. C语言变长数组

    #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct Variable ...

  6. GCC 中零长数组与变长数组

    前两天看程序,发现在某个函数中有下面这段程序: int n; //define a variable n int array[n]; //define an array with length n 在 ...

  7. C++内存分配及变长数组的动态分配

    //------------------------------------------------------------------------------------------------ 第 ...

  8. PL/SQL 嵌套表变长数组和索引表[转]

    关于PL/SQL中这三种数组的介绍,不想写了.转一篇日志吧…… 链接:http://www.blogjava.net/decode360/archive/2008/08/08/280825.html ...

  9. 《OOC》笔记(3)——C语言变长参数va_list的用法

    <OOC>笔记(3)——C语言变长参数va_list的用法 C语言中赫赫有名的printf函数,能够接受的参数数目不固定,这就是变长参数.C#里也有params这个关键字用来实现变长参数. ...

随机推荐

  1. 基于RSA securID的Radius二次验证java实现(PAP验证方式)

    基于rsa SecurID的二次验证.RSA server自身可以作为Radius服务器,RSA也可以和其他的软件集合,使用其他的server作为Radius服务器. radius的验证的一般流程如下 ...

  2. 运行PHP

    /usr/local/php/bin/php /home/www/index.php

  3. matrix67:kmp算法详解

    个人认为KMP是最没有必要讲的东西,因为这个东西网上能找到很多资料.但网上的讲法基本上都涉及到“移动(shift)”.“Next函数”等概念,这非常容易产生误解(至少一年半前我看这些资料学习KMP时就 ...

  4. 用PHP编写Hadoop的MapReduce程序

    用PHP编写Hadoop的MapReduce程序     Hadoop流 虽然Hadoop是用Java写的,但是Hadoop提供了Hadoop流,Hadoop流提供一个API, 允许用户使用任何语言编 ...

  5. Linux多线程编程(一)---多线程基本编程

    线程概念 线程是指运行中的程序的调度单位.一个线程指的是进程中一个单一顺序的控制流,也被称为轻量级线程.它是系统独立调度和分配的基本单位.同一进程中的多个线程将共享该系统中的全部系统资源,比如文件描述 ...

  6. Python 执行字符串表达式函数(eval exec execfile)

    eval:计算字符串中的表达式 exec:执行字符串中的语句 execfile:用来执行一个文件 在python 2中exec是语句,在python3中exec变为函数,后面要跟括号.在python3 ...

  7. 我的Python成长之路---第四天---Python基础(14)---2016年1月23日(寒风刺骨)

    一.生成器和迭代器 1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退. ...

  8. POJ2125 Destroying The Graph 二分图 + 最小点权覆盖 + 最小割

    思路来源:http://blog.csdn.net/lenleaves/article/details/7873441 求最小点权覆盖,同样求一个最小割,但是要求出割去了那些边, 只要用最终的剩余网络 ...

  9. Week6(10月17日):周末别忘记运动

    Part I:提问  =========================== 1.多对多.一对多关系的数据实体模型,如何创建? 已知汽车4S店需开发一个客户关系管理系统(CRM),请为其中的客户和汽车 ...

  10. Calling 64-bit assembly language functions lodged inside the Delphi source code

    Code: http://www.atelierweb.com/calling-64-bit-assembly-language-functions-lodged-inside-the-delphi- ...