C语言指针初始化(malloc)

指针初始化问题:

代码:

// point.cpp :malloc的初始化问题
//
/**
*	2019.03.20
*	记录malloc的初始化问题,在其它函数中初始化,和赋值
*	By: 冬天D秘密
*/

#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>

void init(int *pp,int L);	//目的:为p分配sizeof(int) * L 的空间
void print(int *p,int L);	//输出p中的数据

int _tmain(int argc, _TCHAR* argv[])
{
	int *p = NULL;
	int L = 10; 

	init(p,L);
	print(p,L);
	return 0;
}

void init( int *pp,int L)
{
	pp =(int*)malloc(sizeof(int) * L);
	for (int i = 0;i < L;i++)
	{
		*(pp + i) = i + 1;
	}
}

void print(int *p,int L)
{
	while(L-- > 0){ //先对L进行处理
		printf("%d",*(p + L));	
	}
}

上面执行的时候,当执行到print函数中时就会出现错误。

C语言指针初始化(malloc)

原因:执行过初始化函数后还是没有为主函数中的指针p分配空间,所以尝试print的时候会出错。

C语言指针初始化(malloc)

上图:可以看到init(*,*)中的指针pp已经有了空间,所以在init(*,*)中初始化的时候赋值是没有报错的!这样就可以知道pp只是指向了p的地址而已,当pp进行malloc的时候,并不会对p有影响。

解决方案:

方案一、在主函数中进行初始化,然后再用init(*,*)函数赋值

int _tmain(int argc, _TCHAR* argv[])
{
	int *p = NULL;
	int L = 10; 

	p =(int*)malloc(sizeof(int) * L); //直接在主函数中初始化,

	init(p,L);
        printf("解决方案一的结果:");
	print(p,L);
        getchar();
	return 0;
}

void init( int *pp,int L)
{
	
	for (int i = 0;i < L;i++)
	{
		*(pp + i) = i + 1;
	}
}

C语言指针初始化(malloc)

方案二:使用引用

int _tmain(int argc, _TCHAR* argv[])
{
	int *p = NULL;
	int L = 10; 

	

	init(p,L);
	printf("解决方案二的结果:");
	print(p,L);
	getchar();
	return 0;
}

void init( int *&pp,int L) //使用引用,这样子pp和p就是一样了,别名
{
	pp =(int*)malloc(sizeof(int) * L);
	for (int i = 0;i < L;i++)
	{
		*(pp + i) = i + 1;
	}
}

C语言指针初始化(malloc)

通过引用的方式,这样子在其他函数中pp的操作就是直接对p的操作。pp是p的别名,指的是同一个。

方案三:没错,可能你已经想到了,那就是使用二级指针

int _tmain(int argc, _TCHAR* argv[])
{
	int *p = NULL;
	int L = 10; 

	

	init(&p,L);
	printf("解决方案三的结果:");
	print(p,L);
	getchar();
	return 0;
}

void init( int **pp,int L) //二级指针
{
	*pp =(int*)malloc(sizeof(int) * L);
	for (int i = 0;i < L;i++)
	{
		*(*pp + i) = i + 1;
	}
}

C语言指针初始化(malloc)

二级指针同上面的引用。

--------------------------就先这个样子吧-----------------------------

YQY

ABCDEFG