链表的C语言实现方法编程学习_第1页
链表的C语言实现方法编程学习_第2页
链表的C语言实现方法编程学习_第3页
链表的C语言实现方法编程学习_第4页
链表的C语言实现方法编程学习_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

本文格式为Word版,下载可任意编辑——链表的C语言实现方法编程学习C语言的应用范围广泛,具备很强的数据处理才能,不仅仅是在软件开发上,而且各类科研都需要用到C语言,适于编写系统软件,三维,二维图形和动画,概括应用譬如单片机以及嵌入式系统开发。以下是我为大家探寻整理链表的C语言实现方法,梦想能给大家带来扶助!更多精彩内容请实时关注我们考试网!

一、为什么用动态内存调配

但我们未学习链表的时候,假设要存储数量对比多的同类型或同布局的数据的时候,总是使用一个数组。譬如说我们要存储一个班级学生的某科分数,总是定义一个float型存在0.5分数组:

floatscore[30];

但是,在使用数组的时候,总有一个问题困扰着我们:数组理应有多大?

在好多的处境下,你并不能确定要使用多大的数组,譬如上例,你可能并不知道该班级的学生的人数,那么你就要把数组定义得足够大。这样,你的程序在运行时就申请了固定大小的你认为足够大的内存空间。即使你知道该班级的学生数,但是假设由于某种特殊理由人数有增加或者裁减,你又务必重新去修改程序,扩大数组的存储范围。这种调配固定大小的内存调配方法称之为静态内存调配。但是这种内存调配的方法存在对比严重的缺陷,更加是处理某些问题时:在大多数处境下会滥用大量的内存空间,在少数处境下,当你定义的数组不够大时,可能引起下标越界错误,甚至导致严重后果。

那么有没有其它的方法来解决这样的外呢体呢?有,那就是动态内存调配。

所谓动态内存调配就是指在程序执行的过程中动态地调配或者回收存储空间的调配内存的方法。动态内存调配不象数组等静态内存调配方法那样需要预先调配存储空间,而是由系统根据程序的需要即时调配,且调配的大小就是程序要求的大小。从以上动、静态内存调配对比可以知道动态内存调配相对于景泰内存调配的特点:

1、不需要预先调配存储空间;

2、调配的空间可以根据程序的需要扩大或缩小。

二、如何实现动态内存调配及其管理

要实现根据程序的需要动态调配存储空间,就务必用到以下几个函数

1、malloc函数

malloc函数的原型为:

void*mallocunsignedintsize

其作用是在内存的动态存储区中调配一个长度为size的连续空间。其参数是一个无符号整形数,返回值是一个指向所调配的连续存储域的起始地址的指针。还有一点务必留神的是,当函数未能告成调配存储空间如内存缺乏就会返回一个NULL指针。所以在调用该函数时理应检测返回值是否为NULL并执行相应的操作。

下例是一个动态调配的程序:

[cpp]viewplaincopy

#includemalloc.h

#includestdlib.h

mainvoid

/*count是一个计数器,array是一个整型指针,也可以理解为指向一个整型数组的首地址*/

intcount;

int*array;

array=malloc10*sizeofint;

ifarray==NULL

printfOutofmemory!;

exit1;

/*给数组赋值*/

forcount=0;count10;count++

array[count]=count;

/*打印数组元素*/

forcount=0;count10;count++

printf%2d,array[count];

上例中动态调配了10个整型存储区域,然后举行赋值并打印。例中ifarrayint*malloc10*sizeofint==NULL语句可以分为以下几步:

1调配10个整型的连续存储空间,并返回一个指向其起始地址的整型指针

2把此整型指针地址赋给array

3检测返回值是否为NULL

2、free函数

由于内存区域总是有限的,不能不限制地调配下去,而且一个程序要尽量节省资源,所以当所调配的内存区域不用时,就要释放它,以便其它的变量或者程序使用。这时我们就要用到free函数。

其函数原型是:

voidfreevoid*p

作用是释放指针p所指向的内存区。

其参数p务必是从前调用malloc函数或calloc函数另一个动态调配存储区域的函数时返回的指针。给free函数传递其它的值很可能造成死机或其它灾难性的后果。

留神:这里重要的是指针的值,而不是用来申请动态内存的指针本身。例:

int*p1,*p2;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论