C++ -> 在使用动态链表和异质链表产生野指针的步骤 使用异质链表产生野指针的情况,下面是修改书本的例子:

---------------------------------------------------------------------------------------------------------

---------------------------------------------------------------------------------------------------------

--------------------------------------------

//ex8_12.cpp

#include<iostream.h>

#include<string.h>

#include<assert.h>

#include<iomanip.h>

#include"Employee.h"

#include"Manager.h"

#include"PieceWorker.h"

#include"HourlyWorker.h"

viod AddFront(Employee *&h,Employee*&t){ t->next=h; h=t; }

void test3(){

Employee * empHead=NULL,*ptr;

ptr=new Manager(10135,"Manager",1200);

AddFront(empHead,ptr);

ptr=new HourlyWorker(30712,"HourlyWorker",5,8*20);

AddFront(empHead,ptr);

ptr=new PieceWorker(20382,"PieceWorker",0.5,2850);

AddFront(empHead,ptr);

ptr=empHead;

while(ptr){  ptr->print();  ptr=ptr->next;  }

ptr=empHead;

while(ptr){ cout<<ptr->getNmae()<<" "<<ptr->earnings()<<endl;

ptr=ptr->next;    }

}

void main(){  test3();  }

---------------------------------------------------------------------------------------------------修

改-------------------------------------------------------------------------------------------------------

----------------------------------------------

//ex8_12.cpp

#include<iostream.h>

#include<string.h>

#include<assert.h>

#include<iomanip.h>

#include"Employee.h"

#include"Manager.h"

#include"PieceWorker.h"

#include"HourlyWorker.h"

void test1(){  Employee *empHead=NULL, *ptr, *ptr1;    //在什么情况下 指针必须初始才不会产生野指针

empHead=new Manager(10135,"Manager",120);

ptr=empHead;

ptr->next=new HourlyWorker(30712,"HourlyWorker",5,8*20);

ptr=ptr->next;

ptr->next=new PieceWorker(20382,"PieceWorker",0.5,2850);

ptr=ptr->next;

ptr->next=NULL;                  //缺少这个步骤,此后ptr就是野指针,在下面的while()循环会造成程序崩溃

ptr=empHead;

while(ptr){

cout<<ptr->getName()<<" "<<ptr->getNumber();  //方法1

cout<<" "<<ptr->earnings()<<endl; ptr=ptr->next;  }

// do{ cout<<ptr->getName()<<" "<<ptr->getNumber();              //方法2

// cout<<" "<<ptr->earnings()<<endl; ptr=ptr->next; }while(ptr!=NULL);

//for(int i=0;i<3;i++){ cout<<ptr->getName()<<" "<<ptr->getNumber();

//方法3  //cout<<" "<<ptr->earnings()<<endl;  ptr=ptr->next; } }

void main() {   test1(); }

---------------------------------------------------------------------------------------------------------

---------------------------------------------------------------------------------------------------------

--------------------------------------------

产生野指针的3种情况:

1.指针未初始化

指针变量在定义时不会自动初始化成空指针,而是随机的一个值,可能指向任意空间,这就使得该指针成为野指针。因

此指针在初始化时要么指向一个合理的地址,要么初始化为NULL。

2.指针指向的变量被free或delete后没有置为NULL

在调用free或delete释放空间后,指针指向的内容被销毁,空间被释放,但是指针的值并未改变,仍然指向这块内存,

这就使得该指针成为野指针。因此在调用free或 delete之后,应将该指针置为NULL。

3.指针操作超过所指向变量的生存期

当指针指向的变量的声明周期已经结束时,如果指针仍然指向这块空间,就会使得该指针成为野指针。这种错误很难防

范,只有养成良好的编程习惯,才能避免这类情况发生。

注意:野指针只能避免而无法判断

无法判断一个指针是否为野指针,因为野指针本身有值,指向某个内存空间,只是这个值是随机的或错误的。而空指针

具有特殊性和确定性,可以进行判断,因此要避免在程序中出现野指针

C++ -> 在使用动态链表和异质链表产生野指针的步骤的更多相关文章

  1. c++模板编程-异质链表

    概念: 像一个普通的链表结点中,其中成员next通常是指向同类型结点的指针.这就约束了链表中结点必须是同一类型,从而整个链表都只能保存同一类型的数据.而异质链表则是让next指向任何一种类型,也包括存 ...

  2. 基于QT的异质链表实例

    所谓的异质链表就是的节点元素类型能够不同.本实例採用C++抽象类和多态实现. #include <QApplication> #include<QPushButton> #in ...

  3. 【C/C++】动态内存分配和链表

    本文对链表以及C/C++中的动态链表做详细诠释. 什么是链表? 链表是一种重要的数据结构,它最大的优点是可以进行动态的存储分配.链表有单向链表,双向链表,循环链表.对于c,这里我们只讨论单向链表. 我 ...

  4. 数据结构图文解析之:数组、单链表、双链表介绍及C++模板实现

    0. 数据结构图文解析系列 数据结构系列文章 数据结构图文解析之:数组.单链表.双链表介绍及C++模板实现 数据结构图文解析之:栈的简介及C++模板实现 数据结构图文解析之:队列详解与C++模板实现 ...

  5. 链表创建和链表遍历算法的演示_C语言

    今天搞了一个多小时,头是疼的,应该是没休息好吧,学习了数据结构这一节,感觉收益良多,下面贴上代码和心得: /*24_链表创建和链表遍历算法的演示*/ # include <stdio.h> ...

  6. JS实现单链表、单循环链表

    链表 链表是一种物理存储单元上非线性.非连续性的数据结构(它在数据逻辑上是线性的),它的每个节点由两个域组成:数据域和指针域.数据域中存储实际数据,指针域则存储着指针信息,指向链表中的下一个元素或者上 ...

  7. JAVA 链表操作:单链表和双链表

    主要讲述几点: 一.链表的简介 二.链表实现原理和必要性 三.单链表示例 四.双链表示例 一.链表的简介 链表是一种比较常用的数据结构,链表虽然保存比较复杂,但是在查询时候比较便捷,在多种计算机语言都 ...

  8. 数据结构Java实现04----循环链表、仿真链表

    单向循环链表 双向循环链表 仿真链表 一.单向循环链表: 1.概念: 单向循环链表是单链表的另一种形式,其结构特点是链表中最后一个结点的指针不再是结束标记,而是指向整个链表的第一个结点,从而使单链表形 ...

  9. C语言 Linux内核链表(企业级链表)

    //Linux内核链表(企业级链表) #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> ...

随机推荐

  1. RedHat7安装NetCore环境并发布网站

    RedHat7安装NetCore环境并发布网站 1.注册Microsoft签名密钥并添加Microsoft产品提要,每台机器只需注册一次 执行下面的命令即可 rpm -Uvh https://pack ...

  2. java工作流系统jflow表单引擎字段扩展组件介绍

    关键词:工作流快速开发平台  工作流流设计  业务流程管理   asp.net 开源工作流  bpm工作流系统  java工作流主流框架  自定义工作流引擎 表单设计器  流程设计器 装饰类图片 用于 ...

  3. docker之阿里云centos 7.x 启动容器报错处理办法

    最近阿里云服务器(操作系统centOS 7.x) 安装docker,参照阿里云帮助文档https://help.aliyun.com/document_detail/51853.html?spm=a2 ...

  4. Bash脚本编程学习笔记08:函数

    官方资料:Shell Functions (Bash Reference Manual) 简介 正如我们在<Bash脚本编程学习笔记06:条件结构体>中最后所说的,我们应该把一些可能反复执 ...

  5. Badusb 简易制作

    Badusb easy_make 0x00 basic knowledge and equip arduino IDE download address: https://www.arduino.cc ...

  6. linux 磁盘管理2-硬盘分区

    不重启添加硬盘. echo '- - -' > /sys/class/scsi_host/host2/scan       #centos7有效 列出块设备 lsblk 显示块设备列表      ...

  7. Linux学习记录(二):常用工具

    博主使用的操作系统为Ubuntu tmux 终端分屏 安装 Ubuntu使用apt-get安装 sudo apt-get install tmux 使用 默认命令键:Ctrl + B %(百分号) 左 ...

  8. 剑指offer-面试题57_1-和为s的两个数字-双指针

    /* 题目: 输入一个递增数组和一个s,求和等于s的两个数组中的数字. */ /* 思路: 双指针问题. */ #include<iostream> #include<cstring ...

  9. SQLserver 行变列。

    首先看看效果是不是想要的 变成 ok,我的效果达到了.那就记录下代码吧. create table temp1(count_ int,memo nvarchar(40))go insert into ...

  10. Apache Flink 任意 Jar 包上传致 RCE 漏洞复现

    0x00 简介 Flink核心是一个流式的数据流执行引擎,其针对数据流的分布式计算提供了数据分布.数据通信以及容错机制等功能.基于流执行引擎,Flink提供了诸多更高抽象层的API以便用户编写分布式任 ...