C语言动态分配数组

指针方式

可以使用指针,并在需要时通过malloc函数动态分配内存。下面是一个示例:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

// 定义包含动态数组的结构体
struct DynamicArray {
    int size;
    int *array;
};

// 初始化结构体及动态数组
void initDynamicArray(struct DynamicArray *dynArray, int size) {
    dynArray->size = size;
    dynArray->array = (int *)malloc(size * sizeof(int));
    if (dynArray->array == NULL) {
        printf("Memory allocation failed\n");
        exit(1);
    }
}

// 释放动态分配的内存
void freeDynamicArray(struct DynamicArray *dynArray) {
    free(dynArray->array);
    dynArray->array = NULL;
    dynArray->size = 0;
}

int main() {
    int i;
    struct DynamicArray myArray;

    // 初始化结构体及动态数组
    initDynamicArray(&myArray, 5);

    // 给数组赋值
    for (i = 0; i < myArray.size; i++) {
        myArray.array[i] = i * 10;
    }

    // 输出数组元素
    printf("Array elements: ");
    for (i = 0; i < myArray.size; i++) {
        printf("%d ", myArray.array[i]);
    }
    printf("\n");

    // 释放动态分配的内存
    freeDynamicArray(&myArray);

    return 0;
}

在这个示例中,DynamicArray结构体包含了一个整型成员size表示数组的大小,以及一个整型指针array用于存储动态数组。

initDynamicArray函数中,我们通过malloc函数为数组分配内存,然后将分配的内存地址赋值给array成员。在main函数中,我们可以通过结构体变量访问并操作这个动态数组。

最后,在程序结束前,我们使用freeDynamicArray函数释放了动态分配的内存,以避免内存泄漏。

柔性数组

在C语言中,结构体内定义动态数组并没有直接的语言特性支持,但是可以通过一些技巧来实现。其中一种常见的方法是使用柔性数组(Flexible Array Members)。

柔性数组是C99标准引入的特性,允许在结构体的末尾定义一个长度不定的数组。这种数组被称为柔性数组,因为它的大小可以在运行时确定。

下面是一个示例:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

// 定义结构体,包含一个柔性数组成员
struct DynamicArray {
    int size;
    int array[]; // 柔性数组成员,长度不定
};

// 创建并初始化结构体及动态数组
struct DynamicArray* createDynamicArray(int size) {
    struct DynamicArray* dynArray = malloc(sizeof(struct DynamicArray) + size * sizeof(int));
    if (dynArray == NULL) {
        printf("Memory allocation failed\n");
        exit(1);
    }
    dynArray->size = size;
    return dynArray;
}

// 释放动态分配的内存
void freeDynamicArray(struct DynamicArray *dynArray) {
    free(dynArray);
}

int main() {
    int i;
    int size = 5;
    struct DynamicArray* myArray = createDynamicArray(size);

    // 给数组赋值
    for (i = 0; i < size; i++) {
        myArray->array[i] = i * 10;
    }

    // 输出数组元素
    printf("Array elements: ");
    for (i = 0; i < size; i++) {
        printf("%d ", myArray->array[i]);
    }
    printf("\n");

    // 释放动态分配的内存
    freeDynamicArray(myArray);

    return 0;
}

在这个示例中,DynamicArray结构体中包含一个柔性数组成员array,长度不定。在createDynamicArray函数中,我们使用了malloc来分配结构体和柔性数组的内存空间。需要注意的是,柔性数组必须是结构体的最后一个成员。

相关推荐
格林威1 小时前
面阵相机 vs 线阵相机:堡盟与Basler选型差异全解析 +C# 实战演示
开发语言·人工智能·数码相机·计算机视觉·c#·视觉检测·工业相机
菜菜的顾清寒1 小时前
力扣100(20)旋转图像
算法·leetcode·职场和发展
Navigator_Z1 小时前
LeetCode //C - 1025. Divisor Game
c语言·算法·leetcode
深念Y1 小时前
王者荣耀与英雄联盟数值设计对比:穿透、乘算与加算、增伤乘算更厉害,减伤加算更厉害
数学·算法·游戏·建模·游戏策划·moba·数值
budingxiaomoli1 小时前
优选算法-多源bfs解决拓扑排序问题
算法·宽度优先
隔壁大炮1 小时前
10.PyTorch_元素类型转换
人工智能·pytorch·深度学习·算法
The Chosen One9851 小时前
算法题目分享(二分算法)
算法·职场和发展·蓝桥杯
爱编码的小八嘎1 小时前
C语言完美演绎8-19
c语言
玛丽莲茼蒿1 小时前
Leetcode hot100 矩阵置零【中等】
算法·leetcode·矩阵
澈2071 小时前
算法进阶:二叉树翻转与环形链表解析
数据结构·算法·排序算法