将循环单链表以一种顺序复制给另一个报错Thread 1: EXC_BAD_ACCESS (code=EXC_I386_GPFLT)。

void list::seq(int m,list &a, int n)
{
int count=m; //计数器归零
Elem *pre=this->head; //初始化工作指针p
Elem *p=pre->next;
Elem *qre=a.head; //建立存储顺序的链表
Elem *q=qre->next;
cout<<"进入"< for(int i=0;i {
cout while(--count)
{
cout p=p->next;
}
cout<<"24"< if(i!=n-2) //一般情况
{
cout q=p->next; //存储将要删除的节点
cout<<"前2号"< p->next=p->next->next; //将原循环链表去除将要删除的节点
cout<<"前3号"< delete p->next; //删除节点
cout<<"前4号"< q=q->next; //存储链表工作指针后移
cout<<"前n-2"<<endl;
}

        else if(i==n-2)                 //当只剩下两个点的时候
        {
                cout<<"25"<<endl;
                q=p->next;        //存储将要删除的节点
                delete p->next;         //删除节点
                q=q->next;              //存储链表工作指针后移
        }
        cout<<"最后两"<<endl;
    }
q=p;        //存储最后一个节点
head=qre;

}

这代码里面没见有 new, 只见有delete ?

即便需要delete , 也是在最后逻辑里面, 别和你的主干逻辑”复制“混在一起, 要不然review代码也很困难。

遇到野指针,系统一般会提示为Thread 1:EXC_BAD_ACCESS(code=EXC_I386_GPFLT)错误。因为你访问了一块已经不属于你的内存。