Кто-нибудь знает, где ошибка сегментации в этом?

#c #segmentation-fault

#c #ошибка сегментации

Вопрос:

Я новичок в C, поэтому прошу прощения, если это очевидно, но я пытался найти эту ошибку сегментации в течение последних полутора часов. Я комментировал различные части кода, чтобы попытаться найти его. Но когда я исправляю то, что считаю неправильным, ошибка сегментации остается. Код, который я искал, приведен ниже. Любая помощь была бы очень признательна. Сначала я подумал, что это проблема со счетчиком, но потом это больше походило на то, что это был ряд.

 #include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/time.h>
#include <time.h>
#include "utils.h"

int main(int argc, char* argv[])
{
  struct tm *local;
  struct tm *local2;
  time_t start, end;
  time(amp;start); // read and record clock
  local = localtime(amp;start);
  struct timeval tim;
gettimeofday(amp;tim, NULL);
double t1=tim.tv_sec (tim.tv_usec/1000000.0);

  printf("# Start time and date: %s", asctime(local));
  float refVal;
  float tolVal;
  int vFirst, vSecond;
  vFirst = (strcmp(argv[1], "-v") == 0);
  vSecond = (strcmp(argv[5], "-v") == 0);

 int rct;
  int cct;
  int j;
  float row = 0;
  int r;
  int c;

  int counter=0;
  int refFirst;
  int v = 0;
  scanf("%d %d",amp;rct,amp;cct);

  if(vFirst){
    v = 1;
    refFirst = (strcmp(argv[2], "-r")== 0);
    if(refFirst){
      refVal = strtof(argv[3], NULL);
      tolVal = strtof(argv[5], NULL);
    }else{
      tolVal = strtof(argv[3], NULL);
      refVal = strtof(argv[5], NULL);
    }
 }else if(vSecond){
    v = 1;
    refFirst = (strcmp(argv[1], "-r")== 0);
    if(refFirst){
      refVal = strtof(argv[2], NULL);
      tolVal = strtof(argv[4], NULL);
    }else{
      tolVal = strtof(argv[2], NULL);
      refVal = strtof(argv[4], NULL);
    }
  }else{
     refFirst = (strcmp(argv[1], "-r") == 0);
    if(refFirst){
      refVal = strtof(argv[2], NULL);
      tolVal = strtof(argv[4], NULL);
    }else{
      tolVal = strtof(argv[2], NULL);
      refVal = strtof(argv[4], NULL);
    }

    }

float** rows = (float **) malloc(rct * sizeof(float *));
if (rows == 0)
{
fprintf(stderr, "Couldn’t alocate sufficient space.n");
exit(1);
}
int i;
for (i = 0; i < rct; i  )
{
float* row = (float *) malloc(cct * sizeof(float));
if (row == 0)
{
fprintf(stderr, "Couldn’t alocate sufficient row space.n");
exit(1);
}
rows[i] = row;
}

  for(i = 0; i < rct; i  )
    {
        for(j = 0; j < cct; j  )
        {
            scanf("%f", amp;rows[i][j]);
        }
    }
    for(i = 0; i < rct; i  )
      {
        for(j = 0; j < cct; j  )
          {
            if(approxEqual(rows[i][j], refVal, tolVal)){
              counter  ;
              if(v != 1){
              fprintf(stdout, "r=%d, c=%d: %.6fn", i, j, rows[i][j]);
              }
            }
          }
          }


    char found[] = "Found";
    char apprx[] = "approximate matches.";
    printf("%s %d %sn", found, counter, apprx);
    gettimeofday(amp;tim, NULL);
double t2=tim.tv_sec (tim.tv_usec/1000000.0);
printf("%.6lf seconds elapsedn", t2-t1);

}
 

Комментарии:

1. Пришло время научиться использовать отладчик. И редактор, который сохраняет ваш код отформатированным.

2. Приветствия, это была проблема, нет argv [5]

Ответ №1:

Решение было определено в комментариях, но в качестве предложения по обработке command-line ошибок, связанных с вводом, при использовании command-line ввода рекомендуется включить небольшое заявление об использовании, чтобы напомнить пользователям (включая вас), если исполняемый файл вызывается без надлежащего количества / типа аргументов.

Простой пример:

 int main(int argc, char* argv[])
{
     if(argc != 6)
     {
          printf("argc == %d, expected 6.n"Usage: some.exe <arg1> <arg2> ... <arg_n>nProgram will now exit.", argc);
          return 0;
     }
     ...