Evgenii Legotckoi
08 липня 2017 р. 15:31

C++ - Навчальний посібник 006. Структури

Одним із перших кроків у побудові нових типів даних є організація даних у структуру, що об'єднує кілька різних змінних із різними типами даних. Оголошення структури виконується за допомогою ключового слова struct .

Наприклад, оголосимо структуру Vector , у якому зберігатиметься покажчик початку масиву елементів типу double і змінна з кількістю цих елементів.

struct Vector {
    int sz;       // Число элементов
    double∗ elem; // указатель на элементы
};

Змінна типу Vector може бути оголошена в коді таким чином:

Vector v;

Однак саме по собі це оголошення не має користі, оскільки необхідно ініціалізувати цю структуру деяким масивом елементів із заданою кількістю елементів. Можемо це зробити за допомогою наступної функції.

void vector_init(Vector& v, int s)
{
    v.elem = new double[s]; // выделение памяти для массива элементов
    v.sz = s;
}

У цій функції як аргументи передається посилання на об'єкт Vector та кількість елементів, яким необхідно ініціалізувати цей вектор. Оскільки об'єкт типу Vector передається як неконстантний об'єкт, ми можемо модифікувати його.

Оператор new виділяє пам'ять у так званому вільному сховищі (динамічній пам'яті або простому купі).

Просте використання Vector виглядає так:

double read_and_sum(int s)
    // чтение целых чисел из стандартного ввода в возврат их суммы, считаем s положительным 
{
    Vector v;
    vector_init(v,s); // выделяем память под s элементов для v
    for (int i=0; i!=s; ++i)
        cin>>v.elem[i]; // считываем данные в массив элементов

    double sum = 0;
    for (int i=0; i!=s; ++i)
        sum+=v.elem[i];  // Суммируем все элементы
    return sum;
}

Попереду ще довгий шлях до того, як Vector стане гнучким та елегантним, як vector зі стандартної бібліотеки.

Для доступу до елементів структури можна використовувати точку ( dot . ), якщо використовується доступ через ім'я або посилання або −>, якщо доступ використовується через покажчик. Наприклад:

void f(Vector v, Vector& rv, Vector∗ pv)
{
    int i1 = v.sz; // доступ через имя
    int i2 = rv.sz; // доступ через ссылку
    int i4 = pv−>sz; // доступ через указатель
}

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
  • Останні коментарі
  • Evgenii Legotckoi
    16 квітня 2025 р. 17:08
    Благодарю за отзыв. И вам желаю всяческих успехов!
  • IscanderChe
    12 квітня 2025 р. 17:12
    Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
  • AK
    01 квітня 2025 р. 11:41
    Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
  • Evgenii Legotckoi
    09 березня 2025 р. 21:02
    К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
  • VP
    09 березня 2025 р. 16:14
    Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…