千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:郑州千锋IT培训  >  技术干货  >  为什么C链表节点要用malloc函数动态分配大小?

为什么C链表节点要用malloc函数动态分配大小?

来源:千锋教育
发布人:xqq
时间: 2023-10-14 15:42:13

一、C链表节点要用malloc函数动态分配大小的原因

C链表节点要用malloc函数动态分配大小是因为在C语言中链表节点的大小是不确定的,因为它需要根据实际存储的数据类型和节点前后指针的大小进行调整。因此,链表节点通常使用malloc函数动态分配内存空间。

malloc函数是C标准库中用于动态内存分配的函数,可以根据需要动态地分配指定大小的内存。链表节点使用malloc函数动态分配内存空间,可以保证每个节点都具有正确的大小,而不会浪费内存。除此之外,通过动态分配内存,链表节点还可以在运行时进行动态的扩容或缩容,从而更加灵活地管理节点的内存空间。

二、链表简介

1、链表概念

链表是一种常见的基础数据结构,结构体指针在这里得到了充分的利用。链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入节点。链表都有一个头指针,一般以head来表示,存放的是一个地址。链表中的节点分为两类,头结点和一般节点,头结点是没有数据域的。

2、链表的构成

链表中每个节点都分为两部分,一个数据域,一个是指针域。说到这里你应该就明白了,链表就如同车链子一样,head指向名列前茅个元素:名列前茅个元素又指向第二个元素,直到最后一个元素,该元素不再指向其它元素,它称为“表尾”,它的地址部分放一个“NULL”(表示“空地址”),链表到此结束。作为有强大功能的链表,对他的操作当然有许多,比如:链表的创建,修改,删除,插入,输出,排序,反序,清空链表的元素,求链表的长度等等。

3、常见的链表

单链表循环链表双向链表

4、链表的增删改查

我们在进行数组的插入、删除操作的时候,为了保持内存数据的连续性,需要进行大量的数据搬移工作,所以时间复杂度为 O(n);而在链表中插入或者删除一个数据我们并不需要为了保持内存的连续性而搬移节点,因为链表本身的存储空间也不是连续的,所以在链表中插入和删除一个数据是非常快的。

插入数据: 我们只需要将要插入位置的前一个数据单元的next指针指向插入数据的内存地址,插入数据的next指针指向下一个数据的内存地址;删除数据: 将要删除数据的前一个数据单元的next指针指向要删除数据的下一个数据单元的内存地址,然后再删除数据。

5、实现代码

public class MyLinkedList {10     /**11      * 私有的 Node12      */13     private class Node{14         public E e;15         public Node next;16 17         public Node(E e, Node next){18             this.e = e;19             this.next = next;20         }21         public Node(E e){22             this(e, null);23         }24         public Node(){25             this(null, null);26         }27     }28     private Node head;29     private int size;30 31     public MyLinkedList(){32         head = null;33         size = 0;34     }35     public int getSize(){36         return this.size;37     }38     public boolean isEmpty(){39         return size == 0;40     }41 }

三、malloc函数

malloc时动态内存分配函数,用于申请一块连续的指定大小的内存块区域以void*类型返回分配的内存区域地址。malloc函数原型

extern void *malloc(unsigned int num_bytes)//意为分配长度为num_bytes字节的内存块

malloc函数头文件:

#include

malloc函数返回值:如果分配成功则返回指向被分配内存的指针,否则返回空指针NULL。

malloc函数的返回的是无类型指针,在使用时一定要强制转换为所需要的类型。在使用malloc开辟空间时,使用完成一定要释放空间,如果不释放会造内存泄漏。在使用malloc函数开辟的空间中,不要进行指针的移动,因为一旦移动之后可能出现申请的空间和释放空间大小的不匹配。mallo函数返回的实际是一个无类型指针,必须在其前面加上指针类型强制转换才可以使用。

指针自身 = (指针类型*)malloc(sizeof(指针类型)*数据数量)

int *p = NULL;int n = 10;p = (int *)malloc(sizeof(int)*n);

在使用malloc函数之前我们一定要计算字节数,malloc开辟的是用户所需求的字节数大小的空间。

延伸阅读1:C语言简介

C 语言是一种十分强大的语言,可以进行多种方式进行程序的设计,它是一种很有特色的高级语言通过若干个函数组成,它具备构成程序设计的 3 种基本结构顺序,选择和循环结构。C语言编辑简洁明了,运算符丰富且功能强大还有编译预处理功能。此语言的移植性好不同的处理器用不同的编译器编译指令达到移植的效果。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

完全二叉树为什么非常适合顺序存储结构?

2023-10-14

数据结构里面pnext与next有什么区别?

2023-10-14

什么叫精益管理?

2023-10-14

最新文章NEW

Java中遍历数据结构Enumeration和Iterator相比有什么不同?

2023-10-14

数组与集合有什么不同?

2023-10-14

ASPICE是什么?

2023-10-14

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>