赞
踩
在用c++写链表实现交并补时总是出现内存无法访问的问题,甚是苦恼,
问题出在PrintList()这个函数上,而这个函数本身经调试并没有错误,
可以看到下方的指针p内存不合法,也就是访问了非法内存。
于是通过断点检查传入参数的地址,发现linkunion方法中调用了Get()方法。
void linkUnion(LinkList<int> &a, LinkList<int> b)
{}
而在Get()方法中有一句语句为
p = first->next;
这样就导致在linkunion方法之后的linklist_b就已经被更改,所以会内存越界。
以下贴上源代码:
LinkList类:
#pragma once
#include<iostream>
using namespace std;
template<class DataType>
struct Node
{
DataType data;
Node<DataType> *next;
};
template<class DataType>
class LinkList
{
public:
LinkList() { first = new Node<DataType>; first->next = NULL; };
LinkList(DataType a[], int n);
~LinkList()
{
Node<DataType> *p = new Node<DataType>;
while (first != NULL)
<
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。