🚬
C++ Learning
  • 📚Ссылки/медиа
  • 💼Создание проекта. Основы
  • 🔙Escape последовательности
  • 🔥Типы данных
  • 🛡️Переменные
  • 🔒Константы Const
  • 📥Ввод данных в консоль cin. Приведение типов.
    • ✅Задача с операторами
  • 🔖Инкремент и Декремент
  • ♻️Сокращенные арифметические действия
  • ⚖️Логические Операции
  • ‼️if - else
    • ✅Проверка на четность
  • 3️⃣Тернарный оператор
  • 🔀Switch
    • ✅Простой калькулятор на switch
  • 🔄Цикл While
    • ✅Линия из символов
    • ✅Нахождение всех целых нечетных чисел
  • ♾️Цикл For
  • 🛑Оператор break
  • ⏭️Оператор continue
  • 🦽Оператор goto
  • 🗃️Вложенный Цикл / Вложенная конструкция
    • ✅Задача с прямоугольником
  • 📦Массив
    • ✅Нахождение минимального элемента массива
  • 📏функция sizeof()
  • 🎲функция rand()
    • ✅Заполнение массива случайными неповторяющимися числами
  • 🗓️Двумерный массив
    • ✅Заполнение двумерного массива случайными неповторяющимися числами
  • ⚙️Функции
    • 🔩Прототипы функции
    • 🔩Параметры по умолчанию
    • 🔩Перегрузка функций
    • 🔩Шаблоны функции
    • ✅Игра "угадай число"
  • 👁️Область видимости
  • 📚Стек
  • 🪞Рекурсия
  • 👉Указатели
    • *️⃣Разыменование
    • 📦Массив это указатель
    • 🔩Передача параметров функции через указатели
    • ✅Обмен значениями переменных с помощью указателей
  • 📎Ссылки (reference)
    • ✅Обмен значениями между переменными
    • ✅Шаблонная функция обмена значениями
  • 💾new, delete. Выделение / Удаление памяти
    • ⭕NULL / nullptr
  • 📦Динамический массив
    • 💊Двумерный динамический массив
    • 💿Копирование динамического массива
    • Управление массивом. Добавление элемента (push-back)
    • Управление массивом. Удаление элемента (pop-back)
  • 📝Строки
    • 🧩string / конкатенация строк
    • 📏функция strlen()
    • ✅Написать функцию strlen() самому
  • 📩Указатель на функцию
  • 💽Препроцессор #define
    • Макрос
    • Условная компиляция #ifdef #endif #else #ifndef #if
  • 🌐ООП
  • Class / класс, объект класса
    • Методы класса
    • Модификаторы доступа класса. ИНКАПСУЛЯЦИЯ
    • Геттеры и Сеттеры. ИНКАПСУЛЯЦИЯ.
    • Конструктор класса
      • Перегрузка конструктора класса
    • Деструктор класса
    • this / конструктор копирования
    • operator / Перегрузка операторов
      • Перегрузка операторов сравнения ><
      • Перегрузка операторов сложения, вычитания +-
      • Пример класса с конструкторами и перегрузками
  • 😎Friend / дружественные функции, классы
    • ✅Обмен значениями между объектами класса Swap
    • Дружественный метод класса.
  • Методы вне класса
  • ⁉️Ошибки
    • ❌Ошибка с моментальным закрытием консоли из .exe
  • LEETCODE
    • 🟩1.TwoSum
    • 🟩1108. Defanging an IP Address
    • 🟩2011. Final Value of Variable After Performing Operations
    • 🟩9. Palindrome Number
Powered by GitBook
On this page

функция sizeof()

определяет размер элемента в байтах

sizeof - дает нам узнать сколько места в байтах занимает элемент

синтаксис
sizeof(int) // узнаем размер типа данных int => 4 байта
sizeof(double) // узнаем размер типа данных double => 8 байт


int arr[4]{5,4,23,532}
sizeof(arr) // узнаем размер массива => 16 байт

// каждый элемент массива является как бы отдельной переменной такого же типа данных
// =>   4*4 = 16 байт

Например мы не знаем количество элементов массива и не хотим создавать отдельную переменную для расчета. Мы можем использовать sizeof(), что бы узнать размер массива в байтах. Затем получившиеся значение мы делим на тип данных массива и узнаем количество элементов в массиве.

Определяем длину массива
int arr[]{ 13,32,32,22 };

for (int i = 0; i < sizeof(arr)/sizeof(int); i++)
{
	cout << arr[i] << endl;
}


//  мы делим размер массива на размер его типа данных,  
//  что бы узнать сколько в нем элементов                    sizeof(arr)/sizeof(int)
//  =>   20 / 4 = 5 элементов массива

Допустим, мы знаем что в дальнейшем тип данных массива может быть изменен. Например мы изменили int arr[] на double arr[]. Тогда в таком случае, мы можем взять за размер типа данных первый элемент массива т.к он всегда соответствует типу данных массива sizeof(arr[0])

Определяем длину массива
for(int i = 0; i < sizeof(arr)/sizeof(arr[0]); i++)
{
   cout << arr[i] << endl;
}

PreviousНахождение минимального элемента массиваNextфункция rand()

Last updated 8 months ago

📏
Page cover image