大一C语言学习笔记(9)---指针篇--从”内存的使用“和“流程控制”的角度来理解“指针变量的使用‘

2021/11/2 7:13:07

本文主要是介绍大一C语言学习笔记(9)---指针篇--从”内存的使用“和“流程控制”的角度来理解“指针变量的使用‘,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

#深入理解指针变量

举个错误栗子:

//以下代码的目的是输出100和1000,但输出结果只有一个100
#include<stdio.h>
#include<malloc.h>
int *zhizhen;
void junhe(int *p)
{
	*zhizhen=1000;//原因出现在这
	p=zhizhen;
}
int main()
{
	int *p;
	p=(int *)malloc(100);
	*p=100;
	printf("%d\n",*p);
	free(p);
	junhe(p);
	printf("%d\n",*p);
	return 0;
}

运行结果:

100

--------------------------------
Process exited after 5.545 seconds with return value 3221225477
请按任意键继续. . .

int *q;

*q=100;

这种直接给指针变量赋值的代码是错误的,“在C语言中可以直接给指针指向的数据赋值“是正确的,但此时指针p并没有指向什么东西,所以自然不可以直接对指针变量(*p)进行赋值;而对于指向动态内存的指针,是可以对指针变量直接赋值的,举个栗子:

 

#include<stdio.h>
#include<malloc.h>
int main()
{
	int *p;
	int *q=(int *)malloc(4);
	//将动态分配的4个字节的内存的地址赋给了指针变量 q 
	*q=100;
	//向指针变量 q 中所储存的地址对应的动态内存放进了’100‘ 
	printf("%d\n",*q);
	//此时动态内存中放的使’100‘ 
	p=q;
	//将指针变量 q 中所储存的地址赋给了指针变量 p ,此时 p 所储存的地址对应的内存即为上面动态分配的内存 
	*p=1000;
	//向指针变量 p 中所储存的地址对应的内存赋值’1000‘ 
	printf("%d\n",*p); 
	printf("%d\n",*q);
	//所以说现在无论是输出 *p 还是 *q ,都是将此时动态内存中所储存的’1000‘给输出来 
	free(q); 
}

运行结果:

100
1000
1000

--------------------------------
Process exited after 0.8258 seconds with return value 1
请按任意键继续. . .

总结:在指针变量没有初始化的时候,使用“ * 指针变量 ”是错误的,这就和其他类型变量没有初始化是一个类型的问题;

         对于指针变量来说,有没有初始化不取决于它指向的内存中有没有储存数据,而取决于它有没有储存地址,如上方代码栗子:

         指针变量有没有初始化?有,它储存了咱们手动分配的4个字节的内存的地址,所以完全可以通过给” * q “赋值来更换动态内存中储存的数据;

 

 

 



这篇关于大一C语言学习笔记(9)---指针篇--从”内存的使用“和“流程控制”的角度来理解“指针变量的使用‘的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程