1

こんにちは、私は C を初めて使用し、言語で最初のプログラムを作成したばかりで、実行しようとするとセグメンテーション違反エラーが発生し続けます。コード全体で私が犯した小さな間違いが複数あると確信しています。私はそれを経験しましたが、どこに間違いがあるのか​​ わかりません。これが私のコードです:

// $Id: crpn.c,v 1.1 2013-10-22 13:28:04-07 - - $

#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;
   int capacity;
   int size;
   double numbers[SIZE];
};

void bad_operator (const char *oper) {
   fflush (NULL);
   fprintf (stderr, "oper=\"%s\"\n", oper);
   fflush (NULL);
   exit_status = EXIT_FAILURE;
   printf("%s: invaild operator\n", oper);
}

void push (stack *the_stack, double number) {
   if (the_stack->size == the_stack->capacity) {
        printf("%a:stack overflow", number);
    }
   else {
        the_stack->numbers[the_stack->size++]=number;
    }
}

void do_binop (stack *the_stack, char oper) {
  if ((the_stack->top)<1) {
        printf("oper=\"%c\":stack underflow\n", oper);
    }
   else {
        double right = the_stack->numbers[the_stack->size--];
        double left = the_stack->numbers[the_stack->size--];
        switch (oper) {
            case '+': push (the_stack, left + right); break;
            case '-': push (the_stack, left - right); break;
            case '*': push (the_stack, left * right); break;
            case '/': push (the_stack, left / right); break;
          }
        }
}

void do_print (stack *the_stack) {
   if (the_stack->top == -1) {
       printf("stack is empty\n");
    }
   else {
       int pos;
       for (pos = 0; pos <= the_stack->top; ++pos) {
          printf("%a\n",the_stack->numbers[pos]);
   }
 }
}

void do_clear (stack *the_stack) {
   the_stack->top = -1;
}

void do_operator (stack *the_stack, const char *oper) {
   switch (oper[0] ) {
         case '+': do_binop (the_stack, '+'); break;
         case '-': do_binop (the_stack, '-'); break;
         case '*': do_binop (the_stack, '*'); break;
         case '/': do_binop (the_stack, '/'); break;
         case ';': do_print (the_stack);      break;
         case '@': do_clear (the_stack);      break;
         default : bad_operator (oper);       break;
   }
}

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

3 に答える 3

4

「あなたに釣りを教えてあげましょう」:

デバッガーは、障害がどこにあるかを正確に教えてくれます。IDE (Xcode、Eclipse、VS) を使用している場合は、適切なインターフェイスがあり、それを使用する必要があります。そうでない場合:

-gスイッチを使用してプログラムをコンパイルしますgcc -g mycode.c。これにより、デバッグ情報が実行可能ファイルに追加されます (デバッガーがより良い情報を提供します)。

$ gdb my_executable
...
> run
...
Segmentation fault
> where

これにより、正確な場所 (どの行番号で機能するか) が得られます。

于 2013-10-24T00:17:05.530 に答える