在将指针传入函数时实际上也是进行值的传递,传递的是指针所代表的地址的值,因此将指针传入函数时,应注意将指针进行初始化,如若不初始化,该指针不确定指向何处,向函数传递该指针的地址值,在函数内部解引用进行操作时便会发生不可预知的情况。如以下情况,如若不对L进行初始化,程序在dev平台上会异常退出。
`#include<stdio.h>
#include<stdlib.h>
#define LIST_INIT_SIZE 100//初始储存容量
#define LISTINCREMENT 10//后续每次多分配10个元素的空间大小
typedef struct{
int * elem;//此程序为线性表的顺序表示,可理解为数组,elem作为数组的基地址
int length;//数组长度
int listsize;//初始储存容量
}SqList;//定义一个名为SqList的结构变量
void InitList_Sq(SqList * );//初始化顺序表
void PrintList( SqList * ); //输出顺序表,方便检验
int main()
{
SqList M;//
SqList * L //;
L = &M;//如若将这三行改为SqList * L(即未初始化)
InitList_Sq(L);
PrintList(L);
return 0;
}
void InitList_Sq(SqList *L)
{
int i;
L->elem = (int )malloc(LIST_INIT_SIZEsizeof(int));
if(!L->elem)