博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++之失控指针、迷途指针、野指针、悬浮指针及空指针[转]
阅读量:4299 次
发布时间:2019-05-27

本文共 954 字,大约阅读时间需要 3 分钟。

原文:

指针就是用来保存内存地址的变量,因此定义了一个指针后就要给它赋一个地址,或初始化为空指针。使用delete释放掉指针指向的内存后,不再使用该指针,将其置为空指针。

1. 失控指针

  • 失控指针:也称迷途指针、野指针、悬浮指针,指的是不指向任何合法的对象的指针,可以指向任何地址,并且对该地址的数值进行修改或删除,可能会造成意想不到的后果。

2. 迷途指针(悬浮指针)

  • 迷途指针:当所指向的对象被释放或者收回,但是对该指针没有作任何的修改,以至于该指针仍旧指向已经回收的内存地址,此情况下该指针称为迷途指针。
  • 若操作系统将这部分已经释放的内存重新分配给另外一个进程,而原来的程序重新引用现在的迷途指针,则将产生无法预料的后果。因为此时迷途指针所指向的内存现在包含的已经完全是不同的数据。通常来说,若原来的程序继续往迷途指针所指向的内存地址写入数据,这些和原来程序不相关的数据将被损坏,进而导致不可预料的程序错误。
  • 这种类型的程序错误,不容易找到问题的原因,通常会导致段错误(Linux系统中)和一般保护错误(Windows系统中)。如果操作系统的内存分配器将已经被覆盖的数据区域再分配,就可能会影响系统的稳定性。

3. 野指针

  • 野指针:未被初始化的指针,野指针所导致的错误和迷途指针非常相似,但野指针的问题更容易被发现。

4. 空指针

  • 空指针:就是一个被赋值为0的指针,它不指向任何的对象或者函数。

5. 重踏指针

  • 重踏指针:被释放后的指针不置为空指针,不再指向任何合法的内存,它仍可能指向原来的内存块,此时再定义一个新的指针,两个指针都指向同一块内存。
  • 经典重踏指针程序实例:
#include 
using namespace std;typedef unsigned short int USHORT;int main() { USHORT *pShort = new USHORT; *pShort = 10; cout<<"pShort = "<
<

运行结果:

pShort = 0x4d11c8*pShort = 10pLong = 0x4d11c8*pLong = 90000*pShort = 20*pLong = 65556

转载地址:http://xhsws.baihongyu.com/

你可能感兴趣的文章
linux安装docker
查看>>
关闭selinx nginx无法使用代理
查看>>
shell 脚本部署项目
查看>>
spring cloud zuul网关上传大文件
查看>>
springboot+mybatis日志显示SQL
查看>>
工作流中文乱码问题解决
查看>>
maven打包本地依赖包
查看>>
spring boot jpa 实现拦截器
查看>>
jenkins + maven+ gitlab 自动化部署
查看>>
Pull Request流程
查看>>
Lambda 表达式
查看>>
函数式数据处理(一)--流
查看>>
java 流使用
查看>>
java 用流收集数据
查看>>
java并行流
查看>>
CompletableFuture 组合式异步编程
查看>>
mysql查询某一个字段是否包含中文字符
查看>>
Java中equals和==的区别
查看>>
JVM内存管理及GC机制
查看>>
Java:按值传递还是按引用传递详细解说
查看>>