野指针,如何规避。

目录 

1:什么是野指针?

2:如何规避野指针

1.1:指针变量的初始化

2.2:指针越界访问

3.3:指针指向的空间如果我们还回去的话,就把指针指针置为NULL 

4.4:指针使用之前检查有效性


1:什么是野指针?

野指针:就是指针指向的位置是不可知(随机性,初始化,不正确,没有明确限制),指针变量在定义时如果未初始化,其值是随机的,指针变量的值是别的变量的地址,意味着指针指向了一个地址是不确定的变量,此时去解引用就是去访问了一个不确定的地址,所以结果是不可知的。

指针越界也会导致野指针问题,这里解释下:就是当你指针指向的范围超过数组名范围时,那么那个指针就是野指针了。

2:如何规避野指针

1.1:指针变量的初始化

	int a = 10;	     
	int* pa = &a;	  //指针变量的初始化

指针常见错误

引用未初始化的指针变量

试图引用未初始化的指针变量是初学者最容易犯的错误。未初始化的指针变量就是“野”指针,它指向的是无效的地址。


有些书上说:“如果指针变量不初始化,那么它可能指向内存中的任何一个存储单元,这样就会很危险。如果正好指向存储着重要数据的内存单元,而且又不小心向这个内存单元中写入了数据,把原来的重要数据给覆盖了,这样就会导致系统崩溃。”这种说法是不正确的!如果真是这样的话就是编译器的一个严重的 BUG!

2.2:指针越界访问

#include<stdio.h>

int main(void)
{
	int arr[10] = { 0 };
	int i = 0;				
	int* p = arr;			 //接收arr数组首元素的地址
	for (i = 0; i <= 12; i++)//当i=10的时候已经是非法访问内存了,因为,我数组名的常量表达式内容只有10个元素。
	{
		*p = i;				//i每次循环赋值给指针p
		p++;				//指针自增+1,代指arr元素+1

		//*p++ = i 也是可以,这里虽说++优先级更高,但是它是后置运算符
	}
	return 0;
}

 指针变量越界数组导致野指针问题!

3.3:指针指向的空间如果我们还回去的话,就把指针指针置为NULL 

NULL——空指针,用来初始化指针或者给指针赋值,可以转到定义看看 #define NULL    ((void *)0)

说的简单一点就是:当你指针不知道怎么赋值,就赋值给一个空指针 NULL  

Null是在计算中具有保留的值,用于指示指针不引用有效对象。程序通常使用空指针来表示条件,例如未知长度列表的结尾或未执行某些操作; 这种空指针的使用可以与可空类型和选项类型中的Nothing值进行比较。

空指针不应与未初始化的指针混淆:保证空指针与指向有效对象的任何指针进行比较。但是,根据语言和实现,未初始化的指针可能没有任何此类保证。它可能与其他有效指针相等; 或者它可能比较等于空指针。它可能在不同的时间做两件事。

	int a = 10;			
	int* pa = &a;

	printf("%d\n", *pa);

	*pa = 20;				//此时当我们不想用它时候
	pa = NULL;				//就把pa指针置成NULL

	printf("%d\n",pa);

4.4:指针使用之前检查有效性

当你指针变量不可以用的时候就把它设置成NULL,当你指针变量可以用的时候就不是NULL。

就是当我们对这个指针进行初始化的话,那么它就是有效的,如果没有初始化那么就是无效的。

	if (pa != NULL)
	{
		//进行使用
	}
	if (pa == NULL)
	{
		//不进行使用
	}

 好了,这已经是第三篇了,希望我可以一直坚持下去,加油!

希望大大们能给个三连+关注,你们的支持就是我前进的动力,(ง •_•)ง.

 

猜你喜欢

转载自blog.csdn.net/weixin_52632755/article/details/119824892