指针和指针的引用
Csdn问
我们的数据结构课上讲到链表,比如在链表初始化的时候:
InitList(LNode *&HL){//这里老师让我们用*&,我十分不理解*&的作用
HL=NULL;
}
指针的引用
因为在链表初始化的时候,
你需要对这个传递进来的 head 指针进行内存分配等操作,
要么传递指向指针的指针进来,
要么使用指针的引用,
否则在 InitList 中进行的内存分配不能反馈到实参指针中, 函数无效,初始化失败,并造成内存泄漏,在函数内部new之后分配了内存空间,但是head此时还是NULL,因为函数的形参是值类型而非引用类型,函数形参的改变无法影响到实参的值就是head的值造成函数无效,不仅如此,由于函数退出时指针也就自动从栈中退出。指针已经找不到了,但是指针指向的内存是new出来的也就是从堆上分配的,所以不会跟着函数的退出而退出,这样就造成指针指向的内存还在,但是指向该内存的指针已经无法找到,从而造成了内存泄漏
#include "stdafx.h"
#include <iostream>
using namespace std;
int g;
void f1(int*a)
{
a=&g;
}
void f2(int*&a)
{
a=&g;
}
int _tmain(int argc, _TCHAR* argv[])
{
int x=12;
int *p=&x;
cout<<p<<endl;
f1(p);
cout<<p<<endl;
f2(p);
cout<<p<<endl;
return 0;
}
#include <iostream>
using namespace std;
int g;
void f1(int*a)
{
a=&g;
}
void f2(int*&a)
{
a=&g;
}
int _tmain(int argc, _TCHAR* argv[])
{
int x=12;
int *p=&x;
cout<<p<<endl;
f1(p);
cout<<p<<endl;
f2(p);
cout<<p<<endl;
return 0;
}