【C 语言】结构体 ( 结构体 数组 作为函数参数 | 数组 在 堆内存创建 )

简介: 【C 语言】结构体 ( 结构体 数组 作为函数参数 | 数组 在 堆内存创建 )

文章目录

一、结构体 数组 作为函数参数 ( 数组 在 堆内存创建 )

二、完整代码示例





一、结构体 数组 作为函数参数 ( 数组 在 堆内存创建 )


在上一篇博客 【C 语言】结构体 ( 结构体 数组 作为函数参数 | 数组 在 栈内存创建 ) 的基础上 , 将 栈内存 中的 结构体数组 , 更改为 堆内存 中创建结构体数组 ;


在堆内存中 , 创建 结构体数组 : 传入 二级指针 , 该指针 指向 结构体 指针 , 传入 二级指针 的目的是 , 可以在函数中 , 通过形参 间接赋值 , 达到返回创建堆内存的目的 ;


/**
 * @brief create_student 堆内存中分配内存
 * @param array 二级指针 , 指向结构体数组
 * @return
 */
int create_student(Student **array, int count)
{
    // 返回值
    int ret = 0;
    // 临时变量
    Student *tmp = NULL;
    // 验证二级指针合法性
    if(array == NULL)
    {
        ret = -1;
        return ret;
    }
    // 堆内存中申请内存
    tmp = (Student *)malloc(sizeof(Student) * count);
    // 通过间接赋值 设置返回值
    *array = tmp;
    return ret;
}


释放堆内存中的 结构体 数组 : 传入的参数是 二级指针 , 通过该 二级指针 指向 结构体一级指针 , 将 结构体指针 置空 ;


/**
 * @brief free_student 释放内存
 * @param array
 * @return
 */
int free_student(Student **array)
{
    // 返回值
    int ret = 0;
    // 验证二级指针合法性
    if(array == NULL)
    {
        ret = -1;
        return ret;
    }
    // 释放内存
    free(*array);
    // 指针置空 , 防止野指针
    *array = NULL;
    return ret;
}



二、完整代码示例


完整代码示例 :


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/**
 * @brief The Student struct
 * 定义 结构体 数据类型 , 同时为该结构体类型声明 别名
 * 可以直接使用 别名 结构体变量名 声明结构体类型变量
 * 不需要在前面添加 struct 关键字
 */
typedef struct Student
{
    char name[5];
    int age;
    int id;
}Student;
/**
 * @brief printf_struct_array 打印结构体数组
 * @param array 数组作为函数参数退化为指针
 * @param count 数组中的元素个数
 */
void printf_struct_array(Student *array, int count)
{
    // 循环控制变量
    int i = 0;
    // 验证数组合法性
    if(array == NULL)
    {
        return;
    }
    // 打印结构体数组中的 结构体 age 字段
    for(i = 0; i < count; i++)
    {
        printf("Student age = %d\n", array[i].age);
    }
}
/**
 * @brief sort_struct_array 对结构体数组 按照年龄进行排序
 * @param array 结构体指针
 * @param count 结构体数组的元素个数
 */
void sort_struct_array(Student *array, int count)
{
    // 循环控制变量
    int i = 0, j = 0;
    // 学生年龄
    Student tmp;
    // 验证数组合法性
    if(array == NULL)
    {
        return;
    }
    // 排序
    for(i = 0; i < count; i++)
    {
        for(j = i + 1; j < count; j++)
        {
            if(array[i].age > array[j].age)
            {
                tmp = array[i];
                array[i] = array[j];
                array[j] = tmp;
            }
        }
    }
}
/**
 * @brief create_student 堆内存中分配内存
 * @param array 二级指针 , 指向结构体数组
 * @return
 */
int create_student(Student **array, int count)
{
    // 返回值
    int ret = 0;
    // 临时变量
    Student *tmp = NULL;
    // 验证二级指针合法性
    if(array == NULL)
    {
        ret = -1;
        return ret;
    }
    // 堆内存中申请内存
    tmp = (Student *)malloc(sizeof(Student) * count);
    // 通过间接赋值 设置返回值
    *array = tmp;
    return ret;
}
/**
 * @brief free_student 释放内存
 * @param array
 * @return
 */
int free_student(Student **array)
{
    // 返回值
    int ret = 0;
    // 验证二级指针合法性
    if(array == NULL)
    {
        ret = -1;
        return ret;
    }
    // 释放内存
    free(*array);
    // 指针置空 , 防止野指针
    *array = NULL;
    return ret;
}
/**
 * @brief 主函数入口
 * @return
 */
int main(int argc, char* argv[], char**env)
{
    // 声明结构体数组 , 该数组在栈内存中
    Student *array = NULL;
    // 循环控制变量
    int i = 0;
    // 堆内存中为结构体指针分配内存
    create_student(&array, 3);
    // 命令行中 , 接收输入的年龄
    for(i = 0; i < 3; i++)
    {
        printf("\n Input Age :\n");
        // 命令换行中 接收 输入的年龄 ,
        // 设置到 Student 数组元素的 age 成员中
        scanf("%d", &(array[i].age));
    }
    // 结构体数组 按照 age 排序
    sort_struct_array(array, 3);
    // 打印结构体数组中的 结构体 age 字段
    printf_struct_array(array, 3);
    // 释放堆内存数据
    free_student(&array);
    // 命令行不要退出
    system("pause");
    return 0;
}



执行结果 :



Input Age :
12
 Input Age :
11
 Input Age :
14
Student age = 11
Student age = 12
Student age = 14
请按任意键继续. . .


image.png

目录
相关文章
|
4月前
|
安全 C语言 C++
比较C++的内存分配与管理方式new/delete与C语言中的malloc/realloc/calloc/free。
在实用性方面,C++的内存管理方式提供了面向对象的特性,它是处理构造和析构、需要类型安全和异常处理的首选方案。而C语言的内存管理函数适用于简单的内存分配,例如分配原始内存块或复杂性较低的数据结构,没有构造和析构的要求。当从C迁移到C++,或在C++中使用C代码时,了解两种内存管理方式的差异非常重要。
149 26
|
4月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
267 15
|
9月前
|
存储 人工智能 程序员
一文彻底搞明白C语言的数组
本文详细介绍了C语言中的数组,包括定义、初始化(静态与动态)、存储方式、访问方法及常用操作,如遍历、修改元素和作为函数参数传递。数组是C语言中最基本的数据结构之一,掌握它对编程至关重要。下篇将介绍二维数组,敬请期待!
393 0
一文彻底搞明白C语言的数组
|
11月前
|
算法 Java
堆内存分配策略解密
本文深入探讨了Java虚拟机中堆内存的分配策略,包括新生代(Eden区和Survivor区)与老年代的分配机制。新生代对象优先分配在Eden区,当空间不足时执行Minor GC并将存活对象移至Survivor区;老年代则用于存放长期存活或大对象,避免频繁内存拷贝。通过动态对象年龄判定优化晋升策略,并介绍Full GC触发条件。理解这些策略有助于提高程序性能和稳定性。
|
11月前
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
377 6
|
11月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
777 6
|
4月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
1095 0
|
4月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
317 1

热门文章

最新文章

下一篇
开通oss服务