这种方法在C中使用动态数组结构吗?

时间:2018-09-15 10:27:44

标签: c dynamic-arrays

我只是C语言的初学者,正在寻找动态数组结构,并且遇到了这个youtube tutorial

Code使用指针来创建动态数组,而无需使用像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;

}

1 个答案:

答案 0 :(得分:1)

您的代码中没有动态数组

RacingCar allCars[MaxCars];

此处,数组的最大大小已定义为MaxCars。可能使您感到困惑的是,从main对数组的引用被发送到将值添加到数组中的其他函数。 要在C语言中创建动态数组,请使用malloccallocrealloc