C/C++——柔性数组

时间:2022-05-04
本文章向大家介绍C/C++——柔性数组,主要内容包括1、问题来源、2、解决的方法、参考文献、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

1、问题来源

在博文数据结构和算法——kd树中,在构建kd树的过程中,有如下的一段代码:

#define MAX_LEN 1024

typedef struct KDtree{
        double data[MAX_LEN]; // 数据
        int dim; // 选择的维度
        struct KDtree *left; // 左子树
        struct KDtree *right; // 右子树
}kdtree_node;

在这段代码中,为了存储数据,申请了最大长度为1024的double型数组。若是数据的长度远远小于MAX_LEN,这样的写法,是及其浪费空间的。

2、解决的方法

在C语言中,有如下的一种构建方法:

struct mumble {
        //stuff
     char pc[];    
};

这种写法称为柔性数组,也叫伸缩性数组,即变长数组。即声明结构体的时候不指定声明的数组的大小,等到需要使用的时候根据具体情况申请足够大小的空间。

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

typedef struct mytest{
        int a;
        double b;
        int c[];//c不占用空间,只是作为一个符号地址存在,而且必须是结构体的最后一个成员
}mt;

int main(){
        int t[10] = {0,1,2,3,4,5,6,7,8,9};

        mt* pmt = (mt*)malloc(sizeof(mt) + sizeof(int)*10 + 1);
        int i = 0;
        if (NULL != pmt){
                pmt->a = 1;
                pmt->b = 11;
                for (i = 0; i < 10; i++){
                        (pmt->c)[i] = t[i];
                }
        }


        fprintf(stderr, "mt->:a:%d;b:%lfn", pmt->a, pmt->b);
        for (i = 0; i < 10; i++){
                fprintf(stderr, "%dn", (pmt->c)[i]);
        }
        return 0;
}

注意:柔性数组只能为结构体的最后一个成员。

参考文献