0

ユーザーが在庫から車を追加または削除できるようにするプログラムを作成しています。現在、明示的に名前を指定する代わりにユーザーに車の名前を選択させようとしており、配列名 companyList が値を格納する構造体 CriteriaSelector を作成しましたユーザーに車の名前を選択させると、特定のインデックスの companyList から carname という char 配列に文字列がコピーされ、CarData オブジェクトの carname char 配列にコピーされます。

問題は、以下のコードをコンパイルするたびに、27 行目で「companyList」の前に指定子修飾子リストが必要であるというエラーが表示され、どうすればよいかわかりません。誰でも助けることができますか?

#include <stdio.h>
#include <stdlib.h>


#define MAX_WORD_LENGTH 20


typedef struct cardata{

    char carname[MAX_WORD_LENGTH];
    char carmodel[MAX_WORD_LENGTH];
    char caryear[MAX_WORD_LENGTH];
    char cartype[MAX_WORD_LENGTH];
    int  quantity;

}CarData;


struct node{

    CarData data;
    struct node *next;
    struct node *prev;
}*start=NULL;




typedef struct criteriaselector{

    const char *companyList[10];
    companyList[0] = "Toyota"; <-- This is where error is happening!!(Line 27)
    companyList[1] = "Honda";
    companyList[2] = "Hyundai";
    companyList[3] = "Nissan";
    companyList[4] = "Mitsubishi";
    companyList[5] = "Volksvagon";
    companyList[6] = "Acura";
    companyList[7] = "Ford";
    companyList[8] = "Dodge"
    companyList[9] = "GMC";

}CriteriaSelector;


void insert_first(){
    struct node *ptr;
    CriteriaSelector criteriaselector;
    char carname[MAX_WORD_LENGTH];
    char carmodel[MAX_WORD_LENGTH];
    char caryear[MAX_WORD_LENGTH];
    char cartype[MAX_WORD_LENGTH];
    int  carQuantity;
    int ch;
    printf("\nChoose your car");
    printf("\n\n\n1.Toyota \n2.Honda \n3.Hyundai \n4.Nissan \n5. Mitsubishi \n6. Volksvagon \n7. Acura \n8. Ford \n9. Dodge \n10. GNC   Exit\n");
    scanf("%d", &ch);
    strcpy(carname,criteriaselector.companyList[ch-1]);


    printf("\n\nEnter the car model: ");
    scanf("%s", carmodel);
    printf("\n\nEnter the car year: ");
    scanf("%s", caryear);
    printf("\n\nEnter the car type: ");
    scanf("%s", cartype);
    printf("\n\nEnter the  quantity of models: ");
    scanf("%d", &carQuantity);



    if(start==NULL){

        start=(struct node *)malloc(sizeof(struct node));
        strcpy(start->data.carname,carname);
        strcpy(start->data.carmodel,carmodel);
        strcpy(start->data.caryear,caryear);
        strcpy(start->data.cartype,cartype);
        start->data.quantity=carQuantity;
        start->prev=NULL;
        start->next=NULL;

    }else{

        ptr=start;
        start=(struct node *)malloc(sizeof(struct node));
        strcpy(start->data.carname,carname);
        strcpy(start->data.carmodel,carmodel);
        strcpy(start->data.caryear,caryear);
        strcpy(start->data.cartype,cartype);
        start->data.quantity=carQuantity;
        start->next=ptr;

    }

}


void delete_first(){

    struct node *ptr;
    char carname[MAX_WORD_LENGTH];
    char carmodel[MAX_WORD_LENGTH];
    char caryear[MAX_WORD_LENGTH];
    char cartype[MAX_WORD_LENGTH];
    char modelNumber[MAX_WORD_LENGTH];
    int  carQuantity;

    if(start==NULL){
        printf("\n\nLinked list is empty.\n");
    }else{
        ptr=start;
        printf("\nThe car for which the entry is removed is %s \n",ptr->data.carname);
        strcpy(start->data.carname,carname);
        strcpy(start->data.carmodel,carmodel);
        strcpy(start->data.caryear,caryear);
        strcpy(start->data.cartype,cartype);
        start->data.quantity=carQuantity;
        start=start->next;
        free(ptr);
    }
}


void display()
{
    struct node *ptr=start;
    int i=1;

    if(ptr == NULL){
        printf("\nLinklist is empty.\n");
    }else{
        printf("\nSr. No   Make     Model    Year   Type  Quantity\n");
        while(ptr != NULL){
            printf("\n%d.\t%s   %s   %s   %s   %d\n", i,ptr->data.carname,ptr->data.carmodel,ptr->data.caryear,ptr->data.cartype,ptr->data.quantity);
            ptr = ptr->next;
            i++;
        }

    }
}


int main(void)
{
    int ch;
    do 
    {
        printf("\n\n\n1. Insert \n2. Delete \n3. Display \n4. Exit\n");
        printf("\nEnter your choice: ");
        scanf("%d", &ch);

        switch(ch)
        {

            case 1:
                insert_first();
                break;
            case 2:
                delete_first();
                break;  
            case 3:
                display();
                break;
            case 4:
                exit(0);                                            
            default:
                printf("\n\nInvalid choice. Please try again. \n");

        }

    } while(1);


    return EXIT_SUCCESS;
}
4

2 に答える 2

1

構造体の定義と初期化を混在させることはできません。

typedef struct criteriaselector{

   const char *companyList[10];
   companyList[0] = "Toyota"; // This bit needs to be elsewhere.

代わりに、構造体のインスタンスを宣言した後、値を入力する必要があります。例えば:

typedef struct criteriaselector{
   const char *companyList[10];
}
.....

void some_function() {
    CriteriaSelector criteriaselector;
    criteriaselector.companyList[0] = "Toyota"
     .... etc

ただし、構造体を記述するのではなく、定数を作成するつもりだったようです。構造体定義全体の代わりに、次のことができます。

const char *criteriaselector[10] = {"Toyota", "Honda" ... }

グローバルスコープのどこか。これにより、定数文字列の「グローバル」配列が宣言されます。


余談ですが、constここでの動作には少し微妙なところがあります。この宣言は、「定数文字へのポインターの配列を定義する」ことを示しています。つまり、文字列自体は変更できませんが、ポインターは変更できます。したがって、次のことはできません。

criteriaselector[1][0] = '\0' // changing a character inside a const string

ただし、次のことができます。

criteriaselector[1] = "some other string".

これはおそらくあなたが意図したものではありません。代わりに、次のように「定数文字列への定数ポインタの配列を定義する」と言えます。

const char * const criteriaselector[10] = {"Toyota", "Honda" ... }

そうすれば、文字列の内容や、どの文字列が指されているかを変更できなくなります。

私がリンクしたその質問に対するコメントは、これをもう少し詳しく説明しています。

于 2013-08-07T01:40:27.580 に答える
0

構造体内で変数を初期化することはできません。これは、構造体が変数ではなく型を定義するためです。criteriaselector構造変数(あなたの場合).->アクセス指定子を使用して、構造定義の外で構造メンバーを初期化できます。たとえば、

criteriaselector.companyList[0] = "フォード";

于 2013-08-07T01:46:06.907 に答える