#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;
}
...