Я новичок в C, который ищет структуру динамического массива, и наткнулся на этот учебник YouTube .
. Код использует указатели для создания динамического массива.без использования выделения памяти кучи, как malloc ().Мне просто интересно, если этот подход в порядке или он может стать ошибкой, потому что память может быть перезаписана?
Код:
#include "stdio.h"
typedef struct S_RacingCar {
char name[8];
int speed;
} RacingCar;
const int MaxCars = 4;
void PrintList() {
printf("List Print...\n");
}
int AddCar(RacingCar *car) {
printf("Enter Name And Speed: ");
char input[16];
fgets( input, 15, stdin);
int ok = 0;
int res = sscanf(input, "%s %d", car->name, &car->speed);
if(res == 2) {
ok = 1;
printf("Added:%s Speed:%d\n\n",car->name,car->speed);
} else {
printf("Sorry, error parsing input\n\n");
}
return ok;
}
int main() {
RacingCar allCars[MaxCars];
int numCars = 0;
char command[16];
char input[16];
while( fgets( input, 15, stdin) ) {
sscanf(input,"%s",command);
if ( strncmp(command, "quit", 4) == 0) {
printf("\n\nBreaking...\n");
break;
} else if ( strncmp(command, "print", 5) == 0) {
PrintList();
} else if ( strncmp(command, "add", 3) == 0) {
if(numCars < MaxCars) {
numCars += AddCar( &allCars[numCars] );
} else {
printf("Sorry List Is Full!!\n\n");
}
}
}
return 0;
}