Разделы презентаций


Загальні відомості про функцію system ()

Адресація та вказівники в С/С++Вказівник (або покажчик, інколи – посилання) – це змінна, яка може містити адресу деякого іншого об’єкта. Ним може бути (в найпростішому випадку) інша змінна або масив, структура,

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

Слайд 1Загальні відомості про функцію system ()
Функція system(char* str) передає рядок,

що адресується параметром str, як команду для командного процессора операційної

системи. Якщо system() викликається з вказівником NULL, то вона повертає
ненульове значення при умові доступності командного процесора та нуль у супротивному випадку.
Тобто все, що можна зробити у командному рядку Windows, можна виконати функцією system().
Коди кольорів:
0 = Black
1 = Blue
2 = Green
3 = Aqua
4 = Red
5 = Purple
6 = Yellow
7 = White
8 = Gray
9 = Light Blue
A = Light Green
B = Light Aqua
C = Light Red
D = Light Purple
E = Light Yellow
F = Bright White
Загальні відомості про функцію system ()Функція system(char* str) передає рядок, що адресується параметром str, як команду для

Слайд 2Адресація та вказівники в С/С++
Вказівник (або покажчик, інколи – посилання)

– це змінна, яка може містити адресу деякого іншого об’єкта.

Ним може бути (в найпростішому випадку) інша змінна або масив, структура, функція, клас (в С++) тощо.
Синтаксис визначення вказівника:
<тип> * <ідентифікатор_вказівника>;
Приклади.
int* p_i; //p_i – вказівник на тип int, p_i має тип int*
char* p_c;//p_c – вказівник на тип char, має тип char*
void* p; //p – аморфний («нетиповий»)вказівник,
// його тип – void*
В цих прикладах вказівники поки що не вказують ні на які об’єкти – вони не проініціалізовані.
Проте, якщо p – вказівник на деяку існуючу змінну, то *p – це сама змінна. Тут * – є операцією розадресації вказівника (dereferencing).
Адресація та вказівники в С/С++Вказівник (або покажчик, інколи – посилання) – це змінна, яка може містити адресу

Слайд 3Яке значення можна присвоїти вказівнику? Будь-який числовий літерал – це

неприпустиме рішення.
В мові С для ініціалізації вказівника можна використати один

з двох способів:
ініціалізація вказівника адресою існуючої змінної;
ініціалізація вказівника адресою динамічно виділеної пам’яті (з допомогою функції malloc(), calloc()).
В мові С++ для ініціалізації вказівника може використовуватись також операція new, яка динамічно виділяє необхідний об'єм пам'яті під змінну.
Приклади.
int i;
int *p_i = &i; // вказівник p_i вказує на змінну i
// унарна операція & - взяття адреси
*p_i = 10; // змінній i присвоєно значення 10
++*p_i; // змінна i збільшена на 1
cout << *p_i; // виводимо значення змінної i
Зауваження. У виразі (*pi)++; дужки обов'язкові на відміну від виразу ++*p_i; – із-за порядку виконання операцій.
Зауваження. Вказівнику будь-якого типу можна присвоїти значення NULL (такий вказівник не вказує на жодну змінну)
Яке значення можна присвоїти вказівнику? Будь-який числовий літерал – це неприпустиме рішення.В мові С для ініціалізації вказівника

Слайд 4Динамічний розподіл пам'яті.
Динамічним розподілом пам'яті керують функції із файлу


( у просторі імен std):
void* malloc (size_t size);
– виділяє size байтів

пам'яті в області Heap і повертає вказівник на початок цієї області або вказівник NULL, якщо пам’ять не виділена.
void* calloc (size_t n, size_t size);
– повертає вказівник на початок області пам'яті, достатньої для збереження n об'єктів розміру size кожний або вказівник NULL, якщо пам’ять не виділена.
void* realloc (void* p, size_t size);
– змінює розмір пам’яті, на яку вказує вказівник p, на size та повертає вказівник на нову область, або вказівник NULL, якщо зміна неможлива. Для частини пам'яті розміру, рівному найменшому із старого та нового значень, зміст не зміниться.
void free (void* p);
– звільняє область пам'яті, на яку вказує вказівник p.
Динамічний розподіл пам'яті.Динамічним розподілом пам'яті керують функції із файлу ( у просторі імен std):	void*	malloc	(size_t size); 		– виділяє

Слайд 5Приклад роботи із вказівником.

int *p; // визначили вказівник
// виділяємо пам’ять

– необхідно привести
// вказівник до відповідного типу:
p = (int*)

malloc (sizeof (int));
printf ("\nВведіть ціле число: ");
scanf ("%i", p); // ввели ціле значення
// вивели його на екран
printf ("\nЧисло = %i\n", *p);
free (p); // звільнили пам’ять
// В стилі С++
p = new int;
// робота із вказівником
delete p; // звільнення пам’яті
Приклад роботи із вказівником.int *p; // визначили вказівник// виділяємо пам’ять – необхідно привести// вказівник до відповідного типу:

Слайд 6Масиви в С/С++
Синтаксис визначення масиву:
[кількість_елементів];
Тут визначає тип

елементів масиву, які індексуються від 0 до кількість_елементів-1 .
Приклади:
int

iArray [10]; //визначили масив із 10 елементів
for (int i = 0; i < 10; i++)
iArray [i] = i*i; //присвоїли значення елементам

Увага: ідентифікатор масиву – константний вказівник на його нульовий елемент, таким чином, *(iArray + i)– це елемент масиву iArray [i] , а &iArray [i] – вказівник на елемент з індексом i, тобто те саме, що iArray + i. (адресна арифметика - далі)
Компілятор не контролює вихід індексу за межі масиву!
Масив можна проініціалізувати в момент визначення:
int iArray [5] = {1, 2, 3, 4, 5};
char text [] = {'H','e','l','l','o','\0'};
Масиви в С/С++Синтаксис визначення масиву: [кількість_елементів];Тут визначає тип елементів масиву, які індексуються від 0 до кількість_елементів-1 .

Слайд 7Адресна арифметика
Для будь-яких вказівників на один тип допустимі перевірки на


рівність та нерівність їх між собою та присвоєння, а також


присвоєння та порівняння з вказівником NULL.
Якщо p1 та p2 – вказівники и на один і той самий масив, то допустимими операціями з ними додатково є такі:
p1 < p2 перевірка: "p1 вказує на елемент масиву з меншим індексом, ніж той, на який вказує p2";
p1 <= p2 перевірка: "p1 вказує на елемент масиву з індексом не більшим, ніж той, на який вказує p2";
p1 > p2 перевірка: "p1 вказує на елемент масиву з більшим індексом, ніж той, на який вказує p2";
p1 >= p2 перевірка: "p1 вказує на елемент масиву з індексом не меншим, ніж той, на який вказує p2";
p2 – p1 кількість елементів масиву між елементами, що адресуються p2 та p1;
p1 + k вказівник на k-ий елемент масиву, рахуючи вперед від елементу, на який вказує p1.
p1 – k вказівник на k-ий елемент масиву, рахуючи назад від елементу, на який вказує p1.

Слайд 8Символьні масиви
Текстовий масив може бути визначеним і в такий спосіб


(підходить лише для текстових масивів):
char* ptext = "Приклад визначення

тексту ";
або
char text [20] = "Інший приклад";
(Тут важливо, щоб кількість елементів в масиві не перевищувала кількість символів текстової константи).
Перший приклад дозволяє повторне визначення
вказівника, наприклад:
ptext = text; // так можна
text = ptext; // а так – ні!
Символьні масивиТекстовий масив може бути визначеним і в такий спосіб (підходить лише для текстових масивів): char* ptext

Слайд 9Багатовимірні масиви
Синтаксис визначення двовимірного масиву:
[кількість_елементів1][кількість_елементів2];
Приклади:
int arr [2][3]; //визначили

масив із 2*3 елементів
Елементи багатовимірних масивів розташовані в пам’яті послідовно

таким чином, що найшвидше змінюється останній індекс.
Для даного прикладу:
arr [0][0] arr [0][1] arr [0][2] arr [1][0] arr [1][1] arr [1][2]
Для такого масиву ідентифікатор arr – це вказівник на масив вказівників на його рядки. Тому до окремого елементу можна звертатись або прямою індексацією: arr [i][j] або через вказівники: *(*(arr + i) + j).
Багатовимірні масивиСинтаксис визначення двовимірного масиву: [кількість_елементів1][кількість_елементів2];Приклади:int arr [2][3]; //визначили масив із 2*3 елементівЕлементи багатовимірних масивів розташовані в

Слайд 10Багатовимірні масиви
Вище наведений приклад визначення та звертання до елементів статичного

масиву, тобто з фіксованими при визначенні розмірностями. А як створити

динамічний двовимірний масив?
Одна з можливостей – двовимірний масив використовувати як ланцюжок послідовно розташованих рядків (власне, так він і зберігається в пам’яті). Наприклад, виділимо пам’ять під масив розмірностей N*M :
int *p =(int*)malloc (sizeof(int)*N*M);
Тепер звертання до елементу з індексами [i][j] виглядає так: *(p + i*M + j)
На завершення програми необхідно звільнити пам’ять:
free (p);
Багатовимірні масивиВище наведений приклад визначення та звертання до елементів статичного масиву, тобто з фіксованими при визначенні розмірностями.

Слайд 11Багатовимірні масиви
Інша можливість – двовимірний масив використовувати як

масив вказівників на рядки масиву (тобто масив масивів – саме

так компілятор інтерпретує багатовимірні масиви). Створимо подібний динамічний масив розмірностей N*M :
int **p=(int**)malloc (sizeof(int*)*N);
Тут p – вказівник на масив із N елементів, які будуть вказівниками на рядки. Далі необхідно виділити пам’ять під кожний рядок:
for (int i = 0; i < N; i++)
*(p + i) = (int*) malloc (sizeof (int)*M);
Тепер звертатись до елементу з індексами [i][j] можна як до елементу двохіндексного масиву: p[i][j] або *(*(p + i) + j). Звільнення пам'яті теж має відбутись в циклі:
for (int i = 0; i < N; i++)
free(*(p + i));
free(p);
Багатовимірні масиви  Інша можливість – двовимірний масив використовувати як масив вказівників на рядки масиву (тобто масив

Обратная связь

Если не удалось найти и скачать доклад-презентацию, Вы можете заказать его на нашем сайте. Мы постараемся найти нужный Вам материал и отправим по электронной почте. Не стесняйтесь обращаться к нам, если у вас возникли вопросы или пожелания:

Email: Нажмите что бы посмотреть 

Что такое TheSlide.ru?

Это сайт презентации, докладов, проектов в PowerPoint. Здесь удобно  хранить и делиться своими презентациями с другими пользователями.


Для правообладателей

Яндекс.Метрика