鱼C论坛

 找回密码
 立即注册
查看: 4077|回复: 2

关于栈的创建问题, 可以定义指针类型么

[复制链接]
发表于 2014-1-20 07:10:58 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
最下面是我的程序里的部分代码, 头文件部分是栈的创建和初始化,我的问题是在main函数里定义栈并且初始化时我可以定义指针类型么?因为初始化函数里InitStack需要传进的是地址,比如:
int main()
{
    ElemType c;
    sqStack *s1;//这里定义指针
    InitStack(s1); // 初始化栈s1, 直接传入指针地址
    return 0;
}
源代码里可以编译通过,但是运行时会显示停止运行, 是哪里想不明白呢? 正初学数据结构, 万分感谢!

源代码里的正确代码应该是
int main()
{
    ElemType c;
    sqStack s1;
    InitStack(&s1); // 初始化栈s1,引用s1的地址
    return 0;
}


源代码(部分)

#include <stdio.h>
#include <stdlib.h>

typedef char ElemType;
typedef struct
{
    ElemType *base;
    ElemType *top;
    int stackSize;
}sqStack;

// 函数功能:初始化栈
// 参数*s:栈的地址
void InitStack(sqStack *s)
{
    s->base = (ElemType *)malloc(STACK_INIT_SIZE * sizeof(ElemType));
    if( !s->base )
    {
        exit(0);
    }

    s->top = s->base;
    s->stackSize = STACK_INIT_SIZE;
}

int main()
{
    ElemType c;
    sqStack s1;
    InitStack(&s1); // 初始化栈s1
    return 0;
}

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-1-25 03:12:36 | 显示全部楼层
这是c语言的问题。根据你的InitStack的实现,你传入的指针不能为NULL,你的函数最好先加上这个判断;其次,指针说白了就是存储该对象的空间的首地址,你仅仅定义了一个指针变量,却不分配相应的空间,很显然不能用啊。可以定义一个指针变量后,malloc一段空间给它,然后就没得问题了,不过结束后要free掉这个空间。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-13 20:54:48 | 显示全部楼层
故乡的风 发表于 2014-1-25 03:12
这是c语言的问题。根据你的InitStack的实现,你传入的指针不能为NULL,你的函数最好先加上这个判断;其次, ...

刚好碰上这个问题,亲的回答太棒了~~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-16 11:35:17 From FishC Mobile | 显示全部楼层
回帖是一种美德
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-29 07:08:19 | 显示全部楼层
指针指针,,他本身只是4字节的东西,,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-31 10:59:37 | 显示全部楼层
支持楼主
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-31 12:30:49 | 显示全部楼层
强烈支持楼主ing……
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-25 06:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表