КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Void main(void). int *iptr; // Объявление указателя
Void main(void) Void main(void) Void main(void) Void main(void) { int *iptr; // Объявление указателя int count = 1; iptr = &count; // Инициализация указателя printf(“Значение iptr равно %x,\nЗначение count равно %d\n”,iptr,count); printf(“Адрес count равен %x \n”,&count); } В результате выполнения программы будут выведены: адрес (например ffce), значение (1), адрес(ffce).
// Пример 3.2. //Изменение значения по указателю #include <stdio.h> { int count = 10; int *iptr; // Объявление указателя iptr=&count; // Инициализация указателя printf(“По адресу iptr %x находится значение *iptr %d\n”,iptr,*iptr); *iptr=25; printf(“Новое значение count равно %d \n”,count); }
Массив — это несколько объектов, хранимых в памяти последовательно друг за другом. Обращение к массиву осуществляется с помощью индекса (целое число). Все массивы в качестве нижней границы индекса имеют нуль. Верхняя граница задается при описании массива. Форма объявления массива размерности N:
тип имя_массива[размер 1][размер 2]...[размер N];
Многомерные массивы хранятся в памяти по строкам, т.е. быстрее всего изменяется последний индекс. Размер массива обычно задается константой, которая определяется директивой #define вначале программы. Размер памяти, отводимый под один элемент массива, определяется базовым типом. Линейный массив — это вектор. В примерах 3.3 и 3.4 показаны: описание, инициализация и вывод элементов массива в цикле в основной программе и в функции show_array(). // Пример 3.3. // Описание, инициализация, вывод в цикле элементов массива #include <stdio.h> { int i, values[5]={80, 70, 90, 85, 80}; for(i=0; i<5; i++) printf("values[%d] = %d \n", i, values[i]); } // Пример 3.4. // Использование функции для вывода элементов массива #include <stdio.h> void show_array(int values[], int number) { int i; for(i=0; i<number; i++) printf(" %d \n", values[i]); } { int scores[5]={20, 10, 30, 15, 40}; show_array(scores,5); }
Имя массива является его адресом. При передаче имени массива в функцию размер массива для компилятора не имеет значения. Компилятор рассматривает массивы как указатели и помещает в стек только адрес первого элемента массива.
// Пример 3.5. //Вывод адресов массивов #include <stdio.h> { int count[10]; float salaries[5]; long distances[10]; printf("Начальный адрес массива count - %x\n",count); printf("Начальный адрес массива salaries - %x\n",salaries); printf("Начальный адрес массива distances - %x\n",distances); }
Классическим примером линейного массива (размерности 1) является строка символов. В языке С нет переменной типа string (строка). Символьная строка — это одномерный массив типа char, заканчивающийся нулевым байтом. Нулевой байт – это байт, каждый бит которого равен нулю. Для нулевого байта определена специальная символьная константа ‘\0’. Поэтому при описании массива надо отводить лишний байт. Если строка содержит N символов, надо задавать размер массива N + 1.
// Пример 3.6. // Пример массива символов #include <stdio.h>
Дата добавления: 2014-12-27; Просмотров: 349; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |