免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1122 | 回复: 9
打印 上一主题 下一主题

指针的问题,多谢!!!!!!!!!!!!!! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-04-12 09:55 |只看该作者 |倒序浏览
请诸位高手帮小弟看看这段代码有什么问题,总是有执行错误,多谢!!
#include<iostream.h>;

typedef struct Node{
        char ch;
        Node *next;
};

void EnQueue(char ch,Node *head,Node *tail)
{
        Node *p=new Node;
        p->;ch=ch;
        p->;next=NULL;
        if(head!=NULL)
                tail->;next=p;
        else
                head=p;
        tail=p;
        delete p;
        return;
}

void main()
{
        Node *head=new Node;
        Node *tail=new Node;
        head=NULL;
        tail=NULL;
        EnQueue('A',head,tail);
        cout<<head->;ch;     //问题好像出在这句话,执行时,它说
                                                //0x00000000内存不能引用;
}

论坛徽章:
0
2 [报告]
发表于 2003-04-12 10:22 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

你把分配给P的空间DELETE掉了啊
当然不能引用了
在 你的例子里head指向的空间就是P指向的空间。

论坛徽章:
0
3 [报告]
发表于 2003-04-12 11:59 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

原帖由 "unicorns" 发表:
你把分配给P的空间DELETE掉了啊
当然不能引用了
在 你的例子里head指向的空间就是P指向的空间。


"head指向的空间就是P指向的空间"???

main()里面的 "head" 和 EnQueue() 里面的 "head" 是两个不同的变量来的。
main()里面的 "head"的值 由始至终都没有变,始终是 NULL.
所以 在main()里 head->;ch 就引起 "Segmentation fault (core dumped)", 并不是由于 EnQueue()里面 delete 了 p 引起的。

论坛徽章:
0
4 [报告]
发表于 2003-04-12 13:43 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

我同意uiibono的说法,main中的head和调用过程中的head是两回事,建议改用指针函数,详细情况见<<高质量c++编程>;>;

论坛徽章:
0
5 [报告]
发表于 2003-04-12 14:13 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

如果想返回指针时
要使用二级指针

例子
func(int ** c)
{
    *c=new int;
}

论坛徽章:
0
6 [报告]
发表于 2003-04-12 14:39 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

哦,hoho
不好意思,看错了,没注意
不过他的本意好象是想用这个加入队列
参数应该用指针的指针
即便是那样的话,给P分配的空间也是不应该delete掉的啊
呵呵,已经入了队列的嘛,delete掉了还怎么用啊。

论坛徽章:
0
7 [报告]
发表于 2003-04-14 08:04 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

这个队列能建立起来吗?

论坛徽章:
0
8 [报告]
发表于 2003-04-14 12:44 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!


  1. head=p;
  2. tail=p;
  3. delete p;
  4. return;
复制代码


后面访问这个地址时会报错
因为已delete

论坛徽章:
0
9 [报告]
发表于 2003-04-14 18:20 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!


  1. Node *head=new Node;
  2. Node *tail=new Node;
  3. head=NULL;
  4. tail=NULL;
复制代码

head,tail初始化时你都已分配内存,下面两句你又怎么赋空?到后面你又如何释放初始化时分配的内存。

论坛徽章:
0
10 [报告]
发表于 2003-04-15 00:06 |只看该作者

指针的问题,多谢!!!!!!!!!!!!!!

HOHO

仔细看看还真是错误挺多的

看来楼主要花大力气改了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP