0

我有几年的 java 经验,但我对 C 很陌生。我仍在努力弄清楚何时以及何时不使用指针。我得到了这个基本代码,需要完成'push'方法,以便它将下一个元素推入堆栈,但我收到错误消息:

在非结构中请求成员“顶部”。

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

int exit_status = EXIT_SUCCESS;
#define EMPTY (-1)
#define SIZE 16

typedef struct stack stack;
   struct stack {
   int top;
   double numbers[SIZE];
};

void push (stack *the_stack, double number) {
    if(&&the_stack.top>=SIZE-1){
       printf("error");
    }else{
       the_stack.numbers[&&the_stack.top++ ] = number;
    }
}
int main (int argc, char **argv) {
  if (argc != 1) {
     fprintf (stderr, "Usage: %s\n", basename (argv[0]));
     fflush (NULL);
     exit (EXIT_FAILURE);
  }
stack the_stack;
the_stack.top = EMPTY;
char buffer[1024];
for (;;) {
   int scanrc = scanf ("%1023s", buffer);
   if (scanrc == EOF) break;
   assert (scanrc == 1);
   if (buffer[0] == '#') {
     scanrc = scanf ("%1023[^\n]", buffer);
     continue;
  }
  char *endptr;
  double number = strtod (buffer, &endptr);
  if (*endptr == '\0') {
     push (&the_stack, number);
  }else if (buffer[1] != '\0') {
     bad_operator (buffer);
  }else {
     do_operator (&the_stack, buffer);
  }
}
 return exit_status;
}

我是否忽略了一些非常基本的东西?

4

2 回答 2

1

当访问结构的成员时,有两个运算符:.用于非指针结构的点运算符和用于指向结构的指针的“箭头”运算符->

您的push函数中有一个指向结构的指针,因此您需要使用“箭头”运算符。


您的代码还有其他问题,例如push函数中的双与号。退出程序时您也不需要刷新任何文件,运行时会为您完成。

于 2013-10-21T05:56:34.263 回答
0
It seems very clearly that you have less experience in C. There are lots of compile time errors in your code like for example : 

在 push 函数中 top 和 numbers 应该被调用为: the_stack->top the_stack->numbers[]
一个箭头用于调用指针变量的成员。

现在将其与 Java 进行比较:Java 仅使用引用而不使用指针。但在内部,它们指向内存中的某个位置。

https://www.dropbox.com/s/qfk86yb3drdlmz2/C%20to%20Java.JPG 图片 http://erikdemaine.org/papers/CPE98/paper.pdf 论文

检查此链接以关联 C 代码和 Java 代码。

于 2013-10-21T06:21:53.730 回答