C语言在线运行

版本:
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
2021年程序设计题4 发布于:2023-12-01 22:12 计数排序算法 发布于:2023-12-01 17:34 DGUSII 校验码 发布于:2023-12-01 15:44 数组添加头部字节 发布于:2023-12-01 14:00 创建函数调用 发布于:2023-11-30 17:33 一个数各位数字之和 发布于:2023-11-30 00:40 计数排序实现 发布于:2023-11-29 21:25 计数排序(基于比较) 发布于:2023-11-29 19:58 计数排序算法 发布于:2023-11-29 19:58 计数排序额 发布于:2023-11-29 20:28 计算日期 的程序 发布于:2023-12-01 16:35 堆排序实验 发布于:2023-11-29 17:58 这个是堆排序算法 发布于:2023-11-29 16:51 堆排序实现 发布于:2023-11-29 14:07 线性计数排序 发布于:2023-11-29 10:06 统计排序(非线性) 发布于:2023-11-29 09:28 堆排序C语言 发布于:2023-11-29 08:54 堆排序算法 发布于:2023-11-28 23:59 堆排序算法实验 发布于:2023-11-28 23:33 堆排序使用c语言 发布于:2023-11-28 23:04 堆排序算法 发布于:2023-11-28 20:47 堆排序。。 发布于:2023-11-28 19:13 堆排序。。 发布于:2023-11-28 19:11 堆排序实验 发布于:2023-11-28 19:08 计数排序算法 发布于:2023-11-28 16:51 计数排序算法 发布于:2023-11-28 16:37 线性计数排序算法 发布于:2023-11-29 13:45 计数排序算法 发布于:2023-11-28 16:30 计数排序算法 发布于:2023-11-28 16:30 计数排序算法 发布于:2023-11-28 16:28 计数排序。 发布于:2023-11-28 16:36 计数排序算法 发布于:2023-11-28 16:27 实现线性计数排序 发布于:2023-11-28 16:46 # 镁光B57T TLC地址转换为SLC地址 发布于:2023-11-28 16:18 第十一章:计数排序 发布于:2023-11-28 19:16 计数排序算法 发布于:2023-11-28 16:35 实现计数排序 发布于:2023-11-28 15:33 C语言fprintf与vfprintf用法示例(包含__FUNCTION__的使用) 发布于:2023-11-29 15:04 堆排序算法 发布于:2023-11-28 00:08 堆排序算法 发布于:2023-11-27 23:47 || and && 发布于:2023-11-27 23:29 堆排序实现 发布于:2023-11-27 23:12 堆排序算法 发布于:2023-11-27 23:11 自低向上堆排序 发布于:2023-11-27 23:04 堆排序算法。。 发布于:2023-11-27 22:38 堆排序的实现 发布于:2023-11-27 21:50 堆排序。。 发布于:2023-11-27 20:55 堆排序代码 发布于:2023-11-27 20:39 超级堆排序 发布于:2023-11-27 20:08 堆排序实验 发布于:2023-11-27 20:01 [更多]
显示目录

内存管理



C 内存管理

C 语言为内存的分配和管理提供了几个函数。这些函数可以在 <stdlib.h> 头文件中找到。

序号 函数和描述
1 void *calloc(int num, int size); 该函数分配一个带有 function allocates an array of num 个元素的数组,每个元素的大小为 size 字节。
2 void free(void *address); 该函数释放 address 所指向的h内存块。
3 void *malloc(int num); 该函数分配一个 num 字节的数组,并把它们进行初始化。
4 void *realloc(void *address, int newsize); 该函数重新分配内存,把内存扩展到 newsize

动态分配内存

编程时,如果您预先知道数组的大小,那么定义数组时就比较容易。例如,一个存储人名的数组,它最多容纳 100 个字符,所以您可以定义数组,如下所示:

char name[100];

但是,如果您预先不知道需要存储的文本长度,例如您向存储有关一个主题的详细描述。在这里,我们需要定义一个指针,该指针指向未定义所学内存大小的字符,后续再根据需求来分配内存,如下所示:

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

int main() {
   char name[100];
   char *description;

   strcpy(name, "Zara Ali");

   /* 动态分配内存 */
   description = malloc( 200 * sizeof(char) );
   if( description == NULL )
   {
      fprintf(stderr, "Error - unable to allocate required memory\n");
   }
   else
   {
      strcpy( description, "Zara ali a DPS student in class 10th");
   }
   printf("Name = %s\n", name );
   printf("Description: %s\n", description );
}

当上面的代码被编译和执行时,它会产生下列结果:

Name = Zara Ali
Description: Zara ali a DPS student in class 10th

上面的程序也可以使用 calloc() 来编写,只需要把 malloc 替换为 calloc 即可,如下所示:

calloc(200, sizeof(char));

当动态分配内存时,您有完全控制权,可以传递任何大小的值。而那些预先定义了大小的数组,一旦定义则无法改变大小。

重新调整内存的大小和释放内存

当程序退出时,操作系统会自动释放所有分配给程序的内存,但是,建议您在不需要内存时,都应该调用函数 free() 来释放内存。

或者,您可以通过调用函数 realloc() 来增加或减少已分配的内存块的大小。让我们使用 realloc() 和 free() 函数,再次查看上面的实例:

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

int main() {
   char name[100];
   char *description;

   strcpy(name, "Zara Ali");

   /* 动态分配内存 */
   description = malloc( 30 * sizeof(char) );
   if( description == NULL )
   {
      fprintf(stderr, "Error - unable to allocate required memory\n");
   }
   else
   {
      strcpy( description, "Zara ali a DPS student.");
   }
   /* 假设您想要存储更大的描述信息 */
   description = realloc( description, 100 * sizeof(char) );
   if( description == NULL )
   {
      fprintf(stderr, "Error - unable to allocate required memory\n");
   }
   else
   {
      strcat( description, "She is in class 10th");
   }

   printf("Name = %s\n", name );
   printf("Description: %s\n", description );

   /* 使用 free() 函数释放内存 */
   free(description);
}

当上面的代码被编译和执行时,它会产生下列结果:

Name = Zara Ali
Description: Zara ali a DPS student.She is in class 10th

您可以 尝试一下不重新分配额外的内存,strcat() 函数会生成一个错误,因为存储 description 时可用的内存不足。

由JSRUN为你提供的C语言在线运行、在线编译工具
        JSRUN提供的C语言 在线运行,C语言 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。