学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。
目录
学习日记
前言编辑
一、什么是内存的动态分配
二、怎样建立内存的动态分配
用malloc函数开辟动态存储区
用calloc函数开辟动态存储区
用realloc函数重新分配动态存储区
用free函数释放动态存储区
三、void指针类型
注意
例
C语言指针操作
指针这里分为八个小部分,分别是“指针变量”、“通过指针引用数组”、“*通过指针引用多维数组”、“通过指针引用字符串”、“*指向函数的指针”、“*返回指针值的函数”、“*指针数组和多重指针”、“*动态内存分配与指向它的指针变量” 。
全局变量是分配在内存中的静态存储区的,非静态的局部变量(包括形参)是分配在内存中的动态存储区的,这个存储区是一个称为栈(stack)的区域。除此以外,C语言还允许建立内存动态分配区域,以存放一些临时用的数据,这些数据不必在程序的声明部分定义,也不必等到函数结束时才释放,而是需要时随时开辟,不需要时随时释放。这些数据是临时存放在一个特别的自由存储区,称为堆(heap)区。可以根据需要,向系统申请所需大小的空间。由于未在声明部分定义它们为变量或数组,因此不能通过变量名或数组名去引用这些数据,只能通过指针来引用。
void*malloc(unsigned int size)
作用是在内存的动态存储区中分配一个长度为size的连续空间。形参size的类型定为无符号整型(不允许为负数)。此函数的值(即“返回值”)是所分配区域的第一个字节的地址,或者说,此函数是一个指针型函数,返回的指针指向该分配域的第一个字节。
指针的基类型为void,即不指向任何类型的数据,只提供一个纯地址。
void*calloc(unsigned n,unsigned size)
作用是在内存的动态存储区中分配n个长度为size的连续空间,这个空间一般比较大,足以保存一个数组。 用calloc函数可以为一维数组开辟动态存储空间,n为数组元素个数,每个元素长度为size。这就是动态数组。
void*realloc(void *p,unsigned int size)
如果已经通过malloc函数或calloc函数获得了动态空间,想改变其大小,可以用realloc函数重新分配。 用realloc函数将p所指向的动态空间的大小改变为size。p的值不变。如果重分配不成功,返回NULL。
void free(void *p)
作用是释放指针变量p所指向的动态空间,使这部分空间能重新被其他变量使用。p应是最近一次调用calloc或malloc函数时得到的函数返回值。
C 99允许使用基类型为void的指针类型。可以定义一个基类型为void的指针变量(即void*型变量),它不指向任何类型的数据。在将它的值赋给另一指针变量时由系统对它进行类型转换,使之适合于被赋值的变量的类型。
int *pt;
pt=(int *)malloc(100); //malloc(100)是void *型,把它转换为int *型
不要把“指向void类型”理解为能指向“任何的类型”的数据,而应理解为“指向空类型”或“不指向确定的类型”的数据。
建立动态数组,输入5个学生的成绩,另外用一个函数检查其中有无低于60分的,输出不合格的成绩。
#include
#include //程序中用了malloc函数,应包含stdlib.h
int main()
{ void check(int *); //函数声明
int *p1,i; //p1是int型指针
p1=(int *)malloc(5*sizeof(int)); //开辟动态内存区,将地址转换成int *型,然后放在p1中
for(i=0;i<5;i++)
scanf("%d",p1+i); //输入5个学生的成绩
check(p1); //调用check函数
return 0;
}
void check(int *p) //定义check函数,形参是int*指针
{ int i;
printf("They are fail:");
for(i=0;i<5;i++)
if(p[i]<60) printf("%d ",p[i]); //输出不合格的成绩
printf("\n");
}
C语言指针操作(一)指针变量
C语言指针操作(二)通过指针引用数组
C语言指针操作(三)*通过指针引用多维数组
C语言指针操作(四)通过指针引用字符串
C语言指针操作(五)*指向函数的指针
C语言指针操作(六)*返回指针值的函数
C语言指针操作(七)*指针数组和多重指针
C语言指针操作(八)*动态内存分配与指向它的指针变量