ТОР 5 статей: Методические подходы к анализу финансового состояния предприятия Проблема периодизации русской литературы ХХ века. Краткая характеристика второй половины ХХ века Характеристика шлифовальных кругов и ее маркировка Служебные части речи. Предлог. Союз. Частицы КАТЕГОРИИ:
|
Методы доступа к элементам массивов, использование указателей
В языке СИ под указателями понимают объекты, значением которых являются адреса других объектов памяти (переменных, массивов, функций и т.д.). В общем случае указатель объявляется следующим образом: int *p; Такой указатель может содержать адрес переменной целого типа int. Тип данных, используемый при описании, называется базовым и может быть любым. int a=10; p=&a; Знак & определяет операцию взятия адреса. После такого присвоения указатель p будет содержать адрес переменной a, т.е. указывать на переменную. При помощи такого указателя можно получить доступ к значению переменной при помощи операции разыменования (*p=20;), значение а станет равно 20. В языке СИ между указателями и массивами существует тесная связь. Например, когда объявляется массив в виде int array[25], то этим определяется не только выделение памяти для двадцати пяти элементов массива, но и для указателя с именем array, значение которого равно адресу первого по счету (нулевого) элемента массива, т.е. сам массив остается безымянным, а доступ к элементам массива осуществляется через указатель с именем array. С точки зрения синтаксиса языка указатель arrey является константой, значение которой можно использовать в выражениях, но изменить это значение нельзя. Поскольку имя массива является указателем допустимо, например, такое присваивание: int arrey[25]; int *ptr; ptr=array; Здесь указатель ptr устанавливается на адрес первого элемента массива, причем присваивание ptr=arrey можно записать в эквивалентной форме ptr=&arrey[0]. Для доступа к элементам массива существует два различных способа. Первый способ связан с использованием обычных индексных выражений в квадратных скобках, например, array[16]=3 или array[i+2]=7. При таком способе доступа записываются два выражения, причем второе выражение заключается в квадратные скобки. Одно из этих выражений должно быть указателем, а второе - выражением целого типа. Последовательность записи этих выражений может быть любой, но в квадратных скобках записывается выражение следующее вторым. Поэтому записи array[16] и 16[array] будут эквивалентными и обозначают элемент массива с номером шестнадцать. Указатель используемый в индексном выражении не обязательно должен быть константой, указывающей на какой-либо массив, это может быть и переменная. В частности после выполнения присваивания ptr=array доступ к шестнадцатому элементу массива можно получить с помощью указателя ptr в форме ptr[16] или 16[ptr]. Второй способ доступа к элементам массива связан с использованием адресных выражений и операции разыменовании в форме *(array+16)=3 или *(array+i+2)=7. При таком способе доступа адресное выражение равное адресу шестнадцатого элемента массива тоже может быть записано разными способами *(array+16) или *(16+array). При реализации на компьютере первый способ приводится ко второму, т.е. индексное выражение преобразуется к адресному. Для приведенных примеров array[16] и 16[array] преобразуются в *(array+16). Для доступа к начальному элементу массива (т.е. к элементу с нулевым индексом) можно использовать просто значение указателя array или ptr. Любое из присваиваний *array = 2; array[0]=2; *(array+0)=2; *ptr = 2; ptr[0] = 2; *(ptr+0) = 2; присваивает начальному элементу массива значение 2, но быстрее всего выполнятся присваивания *array=2 и *ptr= 2, так как в них не требуется выполнять операции сложения. Не нашли, что искали? Воспользуйтесь поиском:
|