exc_bad_access в C-программе - PullRequest
       1

exc_bad_access в C-программе

5 голосов
/ 01 августа 2010

Хорошо, я знаю, что здесь есть еще один вопрос о "exc_bad_access", но, похоже, он касается Objective-C и устройства для iPhone, в то время как у меня только обычный C. Я новичок в C и почти закончил свой первыйпрограмма до появления этой ошибки.Я пытался понять это в течение нескольких дней и схожу с ума.Любая помощь приветствуется.глючная функция:

void edit (int i){
    char* z;
    char* y;
    char compare1[] = "on bobbin\b\b\b\b";
    char compare2[] = "not on bobbin";
    char compare3[] = "have\b\b\b\b\b\b";
    char compare4[] = "don't have";
    char wrapedit[] = "wrapped";
    char haveedit[] = "have";
    char editing[9];

    FILE *wrappedlist = fopen("../../wrapped", "r+");
    FILE *havelist = fopen("../../havelist", "r+");

    fseek(wrappedlist, i*14, SEEK_SET);
    fseek(havelist, i*11, SEEK_SET);

    printf("Edit? (y=yes, n=no)");
    fgets(z, 2, stdin);

    if ((*z=='y') && (strncmp(haveslist[i], compare4, (size_t)1) == 0)) {
        printf("Switch \"don't have\" to \"have\"? (y=yes, n=no)");
        fgets(y, 2, stdin);

        if (*y=='y') {
            fputs(compare3, havelist);
            fclose(wrappedlist);
            fclose(havelist);
            return;
        }
        else if(*y=='n'){
            fclose(wrappedlist);
            fclose(havelist);
            return;
        }
        printf("Invalid input.");
        return;
    }

    else if ((*z=='y') && (strncmp(haveslist[i], compare3, (size_t)1) == 0)) {
        fpurge(stdout);
        printf("Edit \"wrapped\" or \"have\"?");
        fpurge(stdin);
        fgets(editing, 9, stdin);

        len = strlen(editing);
        editing[len-1]='\0';

        if (strcmp(editing, wrapedit)==0) {

        if (strncmp(wrapped[i], compare1, (size_t)1)==0) {

            printf("Switch \"on bobbin\" to \"not on bobbin\"? (y=yes, n=no)");
            fgets(y, 2, stdin);
            if (*y=='y') {

                fputs(compare2, wrappedlist);
                fclose(wrappedlist);
                fclose(havelist);
                return;
            }
            else if(*y=='n'){
                fclose(wrappedlist);
                fclose(havelist);
                return;
            }
        }
            else if(strncmp(wrapped[i], compare2, (size_t)1)==0){

                fpurge(stdout);
                printf("Switch \"not on bobbin\" to \"on bobbin\"? (y=yes, n=no)");
                fgets(y, 2, stdin);
                if (*y=='y') {

                    fwrite(compare1, (size_t)strlen(compare1), 1, wrappedlist);
                    fclose(wrappedlist);
                    fclose(havelist);
                    return;
                }
                else if(*y=='n'){
                    fclose(wrappedlist);
                    fclose(havelist);
                    return;
        }
                fpurge(stdout);
                printf("Invalid input.");
        }
            fpurge(stdout);
            printf("You don't want to edit wrapped apparently.");
            fclose(wrappedlist);
            fclose(havelist);
            return;
        }
        else if(strcmp(editing, haveedit)==0){

            if (strncmp(haveslist[i], compare3, 1) == 0){

                printf("Switch \"have\" to \"don't have\"? (y=yes, n=no)");
                fgets(y, 2, stdin);
                if (*y=='y') {
                    fputs(compare4, havelist);
                    fclose(wrappedlist);
                    fclose(havelist);
                    return;
                }
                else if(*y=='n'){
                    fclose(wrappedlist);
                    fclose(havelist);
                    return;
                }
                printf("Invalid input.");
            }
            else if(strncmp(haveslist[i], compare4, 1)==0){

                printf("Switch \"don't have\" to \"have\"? (y=yes, n=no)");
                fgets(y, 2, stdin);
                if (*y=='y') {
                    fputs(compare3, havelist);
                    fclose(wrappedlist);
                    fclose(havelist);
                    return;
                }
                else if(*y=='n'){
                    fclose(wrappedlist);
                    fclose(havelist);
                    return;             
            }
        }
            printf("Invalid input.");
        }
            printf("Not editing.");

        fclose(wrappedlist);
        fclose(havelist);

        return;
    }
    else if(*z=='n'){
        fclose(wrappedlist);
        fclose(havelist);
        return;
    }

    printf("Invalid entry");
    fclose(havelist);
    fclose(wrappedlist);
    return;
}

Я могу ввести символ в fgets после "Редактировать?"подскажите, но тогда я получаю ошибку exc_bad_access.Пожалуйста, помогите, спасибо.код:

Ответы [ 2 ]

7 голосов
/ 01 августа 2010

Это происходит потому, что ваши указатели указывают на отсутствие памяти.

char* z; // pointer points nowhere
/* snip */
fgets(z, 2, stdin); // writing to pointer that points nowhere: boom!

Попытка вставить в z два следующих символа из stdin. Тем не менее, z указывает на никуда не полезного. Вам нужно, чтобы он указывал на существующую память: объявления только одного указателя недостаточно, чтобы получить память рядом с ним.

Возможно, вам нужен буфер из 2 символов:

char z[2];

С этим кодом, z будет указателем на достаточно памяти для 2 символов. (В C массив может быть передан везде, где ожидается указатель.)

Я не слишком подробно изучал ваш код, но у вас будет такая же проблема для y.

2 голосов
/ 01 августа 2010

Вы не выделили памяти для z или y и , они оставлены неинициализированными, поэтому fgets выполняет запись по случайным адресам.

...