C - Программа неправильно печатает

Я борюсь с динамическим распределением памяти и не знаю, что не так с логикой приведенного ниже кода. Может кто-нибудь дать мне объяснение и исправить то, что не так.

struct Books {
char *title = new char[0];
char *author;
int pages = 0;
int price = 0;
};

int main()
{

struct Books book;

/*char size = (char)malloc(sizeof(book.title));*/

printf("The title of the book is:\n");
fgets(book.title, sizeof(book.title), stdin);

printf("The title is:\n %s", book.title);

}

Пожалуйста, подробно расскажите, что вы пытаетесь сделать, каков ожидаемый результат и каков ваш текущий результат.

Andreas 17.12.2018 10:52

Для меня это не похоже на действительный c. Например, «новый» - это не оператор C - это C++.

Simon F 17.12.2018 10:52

Вы не можете инициализировать переменные внутри определения структуры. Удалите все назначения изнутри структуры. Затем установите book.title = malloc( n );, где n - размер в байтах для выделения. Также помогает, если вы знаете разницу между C и C++ и решаете, на каком языке вы действительно программируете.

Lundin 17.12.2018 10:52
new char[0]? Неужели не нужен байт? Но вы читаете элементы sizeof(book.title) (размер указателя, а не указатель на массив). Это не может сработать.
Werner Henze 17.12.2018 10:55

Есть список хороших книг по C++ здесь.

molbdnilo 17.12.2018 11:34
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
5
5
66
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Вот как написать свой код, чтобы он был законным C

struct Books {
    char *title;
    char *author;
    int pages;
    int price;

};

int main()
{

    struct Books book;

    book.title = malloc(100);

    printf("The title of the book is:\n");
    fgets(book.title, 100, stdin);

    printf("The title is:\n %s", book.title);

}

Это будет описано в любой книге по C, вам действительно стоит ее прочитать.

В общем, есть два способа справиться с подобными случаями: вы можете использовать массивы символов с заранее определенным размером, и в этом случае вы должны убедиться, что не записали больше символов, чем может вместить в него массив. Код с массивами заранее определенного размера будет выглядеть так:

struct Books {
    char title[255];
    char author[255];
    int pages;
    int price;
};

int main()
{

    struct Books book;

    printf("The title of the book is:\n");
    fgets(book.title, sizeof(book.title), stdin);

    printf("The title is:\n %s", book.title);
}

В приведенном выше случае допустимо использовать sizeof (book.title), потому что размер известен во время компиляции. Но «заголовок» никогда не может превышать 254 символа.

Другой способ - использовать динамическое распределение памяти:

struct Books {
    char * title;
    char * author;
    int pages;
    int price;
};

int main()
{

    struct Books book;
    book.title = NULL;
    size_t n = 0;

    printf("The title of the book is:\n");
    getline(&book.title, &n, stdin);

    printf("The title is:\n %s", book.title);

    free(book.title);
}

В этом случае функция getline () выделяет вам память, поэтому предопределенного максимального размера строки нет. Но вы должны освободить его самостоятельно, а также не можете использовать sizeof () для получения размера массива.

Другие вопросы по теме