c语言实现顺序栈出错【操作符"="左边的值须为 “左值“

发布于 2022-09-04 14:54:58 字数 826 浏览 13 评论 0

数据结构

typedef struct GOBJ{
    bool hoving;
    int width;
    int height;
    int x;
    int y;
    IMAGE_PNG img; 
}GOBJ;

typedef struct STACK{    
    int msize; // max size
    int top; // stack top
    GOBJ* st; // stack arr
}STACK;

// 顺序栈初始化
void arrStk(STACK* st,int size){
    st->st = (GOBJ*)malloc(sizeof(GOBJ*)*size);
    st->msize = size;
    st->top = -1;
};

bool arrStkPush(STACK* st,GOBJ* gobj){
    if(st->top == st->msize-1){
        printf("the stk is full");
        return false;
    }else{
        st->top = st->top + 1;
        st->st + st->top = gobj; //!!!本行报错(~ ̄(OO) ̄)ブ
        return true;
    }
};

编译过程中报错:error C2106: '=' : left operand must be l-value
环境:vc++6 (作业要求)

求解麻烦了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

舂唻埖巳落 2022-09-11 14:54:58

比左右值更重要的问题是:栈中存储的到底是GOBJ还是指向GOBJ的指针?从声明GOBJ* st看你是要存储GOBJ,而从malloc的调用方式上看你又是要存GOBJ*,然后就混乱了。

如果你要存指针,那么st需要声明成GOBJ** stmalloc也不用强制类型转换了,然后那句入栈就可以用数组记号写成:

st->st[st->top] = gobj;
勿忘心安 2022-09-11 14:54:58

提示你st->st + st->top并不是一个合法的左值,st->st + st->top只是一个值,左值应该是一个可以引用的地址。

From维基百科

左值具有确定的、可以被获得的内存地址。这意味着左值可以是变量,也可以是对指向特定内存地址的指针解引用(dereference)的结果。例如C语言的表达式(4 + 9),在执行时,计算机生成一个整数值13,但因为程序没有明确指定这个13如何在计算机中存储,所以这个表达式产生一个右值。另一方面,如果一个C程序声明了一个变量x并将x赋值为13,那么表达式(x)的值是13,并且是一个左值。

你要不试试这样

GOBJ *tmp = (GOBJ *)(st->st + st->top);
tmp = gobj;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文