Хобрук: Ваш путь к мастерству в программировании

Индексировать фрагмент памяти, используя malloc структур в c

Я не уверен, как индексировать один непрерывный фрагмент динамически выделенной памяти.

typedef struct p
{
    char name[30];
    int age;
} Person;

...в основном

//Create enough memory to hold 20 'Person's
Person *people = (Person *)malloc(sizeof(Person) * 20);

Как я могу проиндексировать это, чтобы установить имя переменной и возраст каждого человека? Учитывая, что файл имеет правильную компоновку.

Я попытался сделать следующее, но после пары итераций я получил segfault.

int i;
for (i = 0; i < 20; i++) {
    fscanf(file, "%s", (people + (i * sizeof(Person)))->name);
    fscanf(file, "%d", &((people + (i * sizeof(Person)))->age));
}    

Есть ли способ индексировать с помощью «[x]»?

Спасибо

27.04.2017

  • Почему вы пометили C++, если хотите только для C? 27.04.2017
  • почему бы тебе не написать fscanf(file, "%d", &people[i].age); и т.д. ? 27.04.2017

Ответы:


1

Я думаю, что путаница здесь связана с тем, как работает арифметика указателей.

Когда вы добавляете x к указателю типа T*, к базовому указателю добавляется не x, а x * sizeof(T). (За исключением void*. Арифметика указателя не определена для void*)

Итак, чтобы исправить ваш случай, вы можете использовать (people + i) вместо (people + i* sizeof(..))

Другой способ сделать это - использовать - people[i].

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

Я надеюсь, что это устраняет путаницу.

27.04.2017
Новые материалы

Освоение информационного поиска: создание интеллектуальных поисковых систем (глава 1)
Глава 1. Поиск по ключевым словам: основы информационного поиска Справочная глава: «Оценка моделей поиска информации: подробное руководство по показателям производительности » Глава 1: «Поиск..

Фишинг — Упаковано и зашифровано
Будучи старшим ИТ-специалистом в небольшой фирме, я могу делать много разных вещей. Одна из этих вещей: специалист по кибербезопасности. Мне нравится это делать, потому что в настоящее время я..

ВЫ РЕГРЕСС ЭТО?
Чтобы понять, когда использовать регрессионный анализ, мы должны сначала понять, что именно он делает. Вот простой ответ, который появляется, когда вы используете Google: Регрессионный..

Не зря же это называют интеллектом
Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

LeetCode Проблема 41. Первый пропущенный положительный результат
LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

Расистский и сексистский робот, обученный в Интернете
Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

Управление состоянием в микрофронтендах
Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..