写个单链表,VS里面可以运行的代码,VScode居然不能运行?指针原因?

一、出现的问题

事情是这样的,当时很着急,写个单链表出来,在VS里面写过一次,在VScode里面也写过一次,老师写的代码有一些罗嗦,于是我思考用自己的的代码风格来写一遍。
啪的一下,很快啊!问题出现了!VS里面可以运行的代码,到了VSocde里就不能运行了!这是为什么!

这是List.cpp中相关代码

bool List::insertByTail(Node* pNode)
{
	Node* tailNode = headNode->next;
	while (tailNode->next != NULL)
	{
		tailNode = tailNode->next;
	}
	Node* newNode = new Node();
	if (newNode == NULL)
	{
		return false;
	}
	newNode->m_iData = pNode->m_iData;
	tailNode->next = newNode;
	newNode->next = NULL;
	m_iLength++;
	return true;
}

二、设计实验

这是Main函数相关代码,用来做实验找到问题所在
	Node* newNode = new Node();
	cout << newNode->next << endl;
按照顺序分别是Node.h和Node.cpp文件
#ifndef NODE_H
#define NODE_H

class Node
{
public:
	Node();
	void printData();
	~Node();
public:
	int m_iData;
	Node* next;
};

#endif // !NODE_H



Node.cpp
#include"Node.h"
#include<iostream>
using namespace std;

Node::Node() {}

void Node::printData()
{
	cout << m_iData << "\t";
}

Node::~Node() {}

上面的List.cpp代码已经纠正过了,在纠正以前,是没有写newNode->next = NULL;这一行代码的。
为了找到两个编译器,同一段代码,两种结果的原因所在,写了Main.cpp里的两行代码。

三、实验结果

3.1在VS里

在这里插入图片描述
按F5及性能编译,多次运行的结果,均是00000000,也就是说,在VS里面,Node的构造函数,即使不对next指针进行初始化,编译器也会把next自动初始化为NULL。

3.2在VScode里面

在VScode里面使用的是g++命令,实验结果如下
在这里插入图片描述
由图可知,使用g++命令导致了每一次初始化的Node->next的值都不一样,也就是说相当于一个野指针,值是不确定的。

四、实验结论

在VS里面,不加newNode->next=NULL;编译器会自动进行初始化。因此程序代码可以正常运行;
在VScode里面,由于使用了g++命令 ,不加newNode->next=NULL;会出现野指针,newNode->next的默认值是随机的,这个应该跟 gcc 的行为是一样的,MinGW 的初始化的时候,auto 类型的变量,默认值取决于栈内存之前的值。

血淋淋的教训!不要相信编译器,相信自己!

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值