🗊 Презентация Динамические данные

Нажмите для полного просмотра!
Динамические данные, слайд №1 Динамические данные, слайд №2 Динамические данные, слайд №3 Динамические данные, слайд №4 Динамические данные, слайд №5 Динамические данные, слайд №6 Динамические данные, слайд №7 Динамические данные, слайд №8 Динамические данные, слайд №9 Динамические данные, слайд №10 Динамические данные, слайд №11 Динамические данные, слайд №12 Динамические данные, слайд №13 Динамические данные, слайд №14 Динамические данные, слайд №15 Динамические данные, слайд №16 Динамические данные, слайд №17 Динамические данные, слайд №18

Вы можете ознакомиться и скачать презентацию на тему Динамические данные. Доклад-сообщение содержит 18 слайдов. Презентации для любого класса можно скачать бесплатно. Если материал и наш сайт презентаций Mypresentation Вам понравились – поделитесь им с друзьями с помощью социальных кнопок и добавьте в закладки в своем браузере.

Слайды и текст этой презентации


Слайд 1


Динамические данные
Описание слайда:
Динамические данные

Слайд 2


Виды памяти Существует три вида памяти: статическая, стековая и динамическая. Статическая память выделяется еще до начала работы программы, на стадии...
Описание слайда:
Виды памяти Существует три вида памяти: статическая, стековая и динамическая. Статическая память выделяется еще до начала работы программы, на стадии компиляции и сборки.

Слайд 3


Статическая память Существуют два типа статических переменных: Глобальные переменные (определенные вне функций): … int max_num = 100; … void main() {...
Описание слайда:
Статическая память Существуют два типа статических переменных: Глобальные переменные (определенные вне функций): … int max_num = 100; … void main() { … } Статические переменные (определенные со словом static): void main() { … static int max = 100; … }

Слайд 4


Локальные переменные Локальные (или стековые) переменные – это переменные определенные внутри функции (или блока): void my_func() { … int n = 0; … if...
Описание слайда:
Локальные переменные Локальные (или стековые) переменные – это переменные определенные внутри функции (или блока): void my_func() { … int n = 0; … if (n != 0) { int a[] = {0, 2, 4, 5}; … } … } Память выделяется в момент входа в функцию или блок и освобождается в момент выхода из функции или блока.

Слайд 5


Динамическая память Недостаток статической или локальной памяти: количество выделяемой памяти вычисляется на этапе компиляции и сборки. Использование...
Описание слайда:
Динамическая память Недостаток статической или локальной памяти: количество выделяемой памяти вычисляется на этапе компиляции и сборки. Использование динамической памяти позволяет избавиться от данного ограничения.

Слайд 6


Выделение и освобождение памяти Необходимая библиотека: #include Выделение памяти: void* malloc(size_t n); void* calloc(size_t num, size_t size);...
Описание слайда:
Выделение и освобождение памяти Необходимая библиотека: #include Выделение памяти: void* malloc(size_t n); void* calloc(size_t num, size_t size); void* realloc(void *ptr, size_t size); C++: = new ; Освобождение памяти: void free(void *p); C++: delete ;

Слайд 7


Динамические массивы Пример. Ввести с клавиатуры n чисел (n задается пользователем) и вывести их в обратном порядке. Неправильный способ решения...
Описание слайда:
Динамические массивы Пример. Ввести с клавиатуры n чисел (n задается пользователем) и вывести их в обратном порядке. Неправильный способ решения задачи (с использованием локальной переменной массива) : void main() { int n,i; scanf(“%d”, &n); /* вводим кол-во чисел */ int a[n]; /* ошибка. Нельзя создавать массив используя переменную-размер */ for (i = 0; i < n; i++) scanf(“%d”, &a[i]); for (i = n-1; i >=0; i--) printf(“%5d”, a[i]); }

Слайд 8


Динамические массивы Правильный способ решения задачи (с использованием динамической переменной массива): void main() { int n,i; scanf(“%d”, &n); /*...
Описание слайда:
Динамические массивы Правильный способ решения задачи (с использованием динамической переменной массива): void main() { int n,i; scanf(“%d”, &n); /* вводим кол-во чисел */ /* выделяем память под массив */ int *a = (int*)malloc(n * sizeof(int)); for (i = 0; i < n; i++) scanf(“%d”, &a[i]); for (i = n-1; n >=0; i--) printf(“%5d”, a[i]); free(a); /* освобождаем память */ }

Слайд 9


Динамические структуры Выделение памяти под структуру: struct * = (struct *) malloc(sizeof()); Освобождение памяти: free(); Опишем структуру: struct...
Описание слайда:
Динамические структуры Выделение памяти под структуру: struct * = (struct *) malloc(sizeof()); Освобождение памяти: free(); Опишем структуру: struct student { char name[50]; int grade; int group; };

Слайд 10


Массивы динамически создаваемых структур Пример. Формирование массива из динамически создаваемых структур. void main() { /* Объявляем массив...
Описание слайда:
Массивы динамически создаваемых структур Пример. Формирование массива из динамически создаваемых структур. void main() { /* Объявляем массив студентов */ struct student* students[100] = {NULL}; int i,n; scanf(“%d”, &n); /* n - количество студентов */ for (i = 0; i < n; i++) { /* резервируем память */ students[i] = (struct student*)malloc( sizeof(students)); scanf(“%50s %d %d”, &students[i]->name, &students[i]->age, &students[i]->grade); } … }

Слайд 11


Динамические массивы структур Пример. Формирование динамического массива из структур. void main() { /* Объявляем массив студентов */ struct student*...
Описание слайда:
Динамические массивы структур Пример. Формирование динамического массива из структур. void main() { /* Объявляем массив студентов */ struct student* a; int i,n; scanf(“%d”, &n); /* n - количество студентов */ /* резервируем память */ a = (struct student* a) malloc( n * sizeof(struct student)); for (i = 0; i < n; i++) { scanf(“%50s %d %d”, &a[i].name, &a[i].age, &a [i].grade); } … }

Слайд 12


Динамическая память, функции и двумерные массивы #include #include #define N 4 #define L 5 int **AllocateM(int Width, int Height) { int...
Описание слайда:
Динамическая память, функции и двумерные массивы #include #include #define N 4 #define L 5 int **AllocateM(int Width, int Height) { int **m=(int**)malloc(Height*sizeof(int*));//ðàçìåðíîñòü óêàçàòåëÿ int i; for(i=0;i

Слайд 13


Динамические данные, слайд №13
Описание слайда:

Слайд 14


Динамические данные, слайд №14
Описание слайда:

Слайд 15


Динамические данные, слайд №15
Описание слайда:

Слайд 16


Для динамических массивов используют Вариант2: #include using std::cout; using std::cin; void funArray(int **mass, const int nstr, const int nstb);...
Описание слайда:
Для динамических массивов используют Вариант2: #include using std::cout; using std::cin; void funArray(int **mass, const int nstr, const int nstb); int main() { //ввод размера динамического двумерного массива: int N, M; cin >>N>>M; //выделение места в памяти под динамический двумерный массив: int **Arr=new int* [N]; for(int i=0; i

Слайд 17


Динамические данные, слайд №17
Описание слайда:

Слайд 18


Динамические данные, слайд №18
Описание слайда:



Похожие презентации
Mypresentation.ru
Загрузить презентацию