Pole (datový typ)

Pole  je datová struktura , která ukládá sadu hodnot (prvků pole) identifikovaných indexem nebo sadou indexů, které přebírají celočíselné (nebo převoditelné) hodnoty z určitého daného spojitého rozsahu. Jednorozměrné pole si lze představit jako implementaci abstraktního datového typu,  vektoru. V některých programovacích jazycích lze pole také nazývat tabulka, řádek, vektor, matice.

Dimenze pole je počet indexů potřebných k jedinečnému adresování prvku v poli [1] . Podle počtu použitých indexů se pole dělí na jednorozměrná, dvourozměrná, trojrozměrná atd.

Tvar nebo struktura pole - informace o počtu rozměrů a velikosti (délce) pole pro každý z rozměrů [2] ; lze reprezentovat jednorozměrným polem [3] .

Vlastností pole jako datové struktury (na rozdíl např. od propojeného seznamu ) je konstantní výpočetní náročnost přístupu k prvku pole indexem [4] . Pole odkazuje na datové struktury s náhodným přístupem .

V nejjednodušším případě má pole konstantní délku ve všech rozměrech a může ukládat pouze data jednoho typu uvedeného v popisu. Řada jazyků také podporuje dynamická pole , jejichž délka se může během provádění programu měnit, a heterogenní pole , která mohou ukládat data různých typů do různých prvků. Některé konkrétní typy polí používané v různých jazycích a implementacích jsou asociativní pole , strom segmentů , V-seznam , paralelní pole , řídké pole .

Hlavní výhody použití polí jsou snadnost výpočtu adresy prvku podle jeho indexu (protože prvky pole jsou umístěny za sebou), stejná přístupová doba ke všem prvkům, malá velikost prvků sestávají pouze z informačního pole). Mezi nevýhody patří nemožnost odebrat nebo přidat prvek bez posunutí ostatních při použití statických polí a při použití dynamických a heterogenních polí pomalejší výkon kvůli režii zachování dynamiky a heterogenity. Při práci s poli s implementací C (s ukazateli) a bez dalších ovládacích prvků je typickou chybou běhu hrozba přetečení pole a poškození dat.

Možnosti implementace

Pole je uspořádaná sada prvků, z nichž každý ukládá jednu hodnotu, identifikovanou jedním nebo více indexy. V nejjednodušším případě má pole konstantní délku a ukládá datové jednotky stejného typu a celá čísla fungují jako indexy.

Počet použitých indexů pole může být různý: pole s jedním indexem se nazývají jednorozměrná, pole se dvěma se nazývají dvourozměrná a tak dále. Jednorozměrné pole - volně odpovídá vektoru v matematice; dvourozměrný ("řádek", "sloupec") - matice . Nejčastěji se používají pole s jedním nebo dvěma indexy; méně často - se třemi; ještě větší počet indexů je extrémně vzácný.

První prvek pole může mít v závislosti na programovacím jazyce jiný index. Existují tři hlavní typy polí: pole založené na nule ( založené na nule ), založené na jedné ( založené na jedné ) a založené na konkrétní hodnotě dané programátorem ( založené na n ). Počítání od nuly je typičtější pro nízkoúrovňové programovací jazyky , ačkoli se vyskytuje také v jazycích na vysoké úrovni, například se používá téměř ve všech jazycích rodiny C. V řadě jazyků ( Pascal , Ada , Modula-2 ) lze definovat rozsah indexů jako libovolný rozsah hodnot libovolného datového typu, který lze přetypovat na celé číslo, tj. celá čísla, symboly, výčty, dokonce booleovské hodnoty (v druhém případě má pole dva prvky indexované hodnotami „True“ a „False“).

Příklad pevného pole v Pascalu {Jednorozměrné pole celých čísel. Číslování prvků od 1 do 15} a : pole [ 1 .. 15 ] of Integer ; {Dvourozměrné pole znaků. Číslování sloupců podle typu Byte (od 0 do 255) po řádcích od 1 do 5} multiArray : array [ Byte , 1 .. 5 ] of Char ; {Jednorozměrné pole řetězců. Číslování slov (od 0 do 65536)} rangeArray : pole [ Word ] of String ; Příklad pevného pole v C int Array [ 10 ]; // Jednorozměrné pole: celá čísla, velikost 10; // Číslování prvků — od 0 do 9. double Array [ 12 ][ 15 ]; // Dvourozměrné pole: // reálná čísla s dvojitou přesností, // velikost 12 x 15; // Číslování: po řádcích - od 0 do 11, // po sloupcích - od 0 do 14.

V některých programovacích jazycích jsou vícerozměrná pole vytvářena na základě jednorozměrných polí, ve kterých jsou prvky pole [5] .

Příklad JavaScript 2D Array //Vytvořte dvourozměrné pole čísel: var array = [ [ 11 , 12 , 13 , 14 , 15 , 16 ], // První řádek je pole [ 21 , 22 , 23 , 24 , 25 , 26 ] , // Druhý [ 31 , 32 , 33 , 34 , 35 , 36 ] // Třetí ]; // Výstup pole do konzoly: array . forEach (( subArray ) => { // Pro každé dílčí pole, subArray . forEach (( item ) => { // pro každý jeho prvek, console . log ( item ); // vytiskne tento prvek do konzole. }); });

Podpora indexových polí (její vlastní deklarační syntaxe, funkce pro práci s prvky atd.) se nachází ve většině programovacích jazyků na vysoké úrovni . Maximální přípustný rozměr pole, typy a rozsahy hodnot indexu, omezení typů prvků jsou určeny programovacím jazykem nebo konkrétním překladačem .

V programovacích jazycích, které umožňují programátorovi deklarovat své vlastní typy , je obecně možné vytvořit typ "pole". V definici takového typu jsou specifikovány typy a/nebo rozsahy hodnot každého z indexů a typ prvků pole. Deklarovaný typ lze později použít k definování proměnných, formálních parametrů a návratových hodnot funkcí. Některé jazyky podporují operace přiřazení pro proměnné pole (když jedna operace přiřadí všechny prvky pole hodnotám odpovídajících prvků jiného pole).

Deklarace typu pole v Pascalu typ TArrayType = pole [ 0 .. 9 ] of Integer ; (* Pole, která mají následující parametry: 1. Velikost - 10 buněk; 2. Typ prvků vhodných pro uložení - - celá čísla v rozsahu [−32 768; 32 767], - jsou deklarována typem operandu nazvaným "TArrayType" *) var arr1 , arr2 , arr3 : TArrayType ; (* Deklarace tří proměnných pole stejného typu (výše „TArrayType“). *)

V programovacím jazyce APL je pole hlavním datovým typem (nulové pole se nazývá skalární, jednorozměrné pole se nazývá vektor a dvourozměrné pole se nazývá matice) [3] . Kromě přiřazování polí tento jazyk podporuje vektorové a maticové aritmetické operace, z nichž každá se provádí jedním příkazem, operace posunu dat v polích a řazení řádků matice.

Dynamická pole

Pole se nazývají dynamická, jejichž velikost se může během provádění programu měnit. Obyčejná (nedynamická) pole se také nazývají pevná nebo statická .

Dynamická pole lze implementovat jak na úrovni programovacího jazyka, tak na úrovni systémových knihoven. Ve druhém případě je dynamické pole objektem standardní knihovny a všechny operace s ním jsou implementovány v rámci stejné knihovny. Tak či onak, podpora dynamických polí zahrnuje následující vlastnosti:

  1. Popis dynamického pole. Na jazykové úrovni se může jednat o speciální syntaktickou konstrukci, na úrovni knihovny může jít o knihovní datový typ, jehož hodnota je deklarována standardním způsobem. Zpravidla se při popisu (vytváření) dynamického pole udává jeho počáteční velikost, i když to není nutné.
  2. Operace určení aktuální velikosti dynamického pole.
  3. Operace změny velikosti dynamického pole.

Příklad struktur pro práci s dynamickými poli v Delphi :

var // Popis dynamických polí byteArray : Array of Byte ; // Jednorozměrné pole multiArray : Array of Array of string ; // Vícerozměrné pole ... SetLength ( byteArray , 1 ) ; // Nastavte velikost pole na 1 prvek. byteArray [ 0 ] := 16 ; // Psací prvek. SetLength ( byteArray , Length ( byteArray ) + 1 ) ; // Zvětšení velikosti pole o jeden byteArray [ Length ( byteArray ) - 1 ] := 10 ; // Zapíše hodnotu do posledního prvku. WriteLn ( byteArray [ Délka ( byteArray ) - 1 ]) ; // Zobrazí poslední prvek pole. ... SetLength ( multiArray , 20 , 30 ) ; // Nastavení velikosti dvourozměrného pole multiArray [ 10 , 15 ] := 12 ; // Zápis hodnoty SetLength ( multiArray , 10 , 15 ) ; // Zmenšení velikosti WriteLn ( Length ( multiArray ) , ' ' , Length ( multiArray [ 0 ])

Heterogenní pole

Pole se nazývá heterogenní , do jehož různých prvků lze přímo zapsat hodnoty související s různými datovými typy . Pole, které ukládá ukazatele na hodnoty různých typů, není heterogenní, protože data skutečně uložená v poli patří k jedinému typu – typu „ukazatel“. Heterogenní pole jsou vhodná jako univerzální struktura pro ukládání datových sad libovolných typů. Implementace heterogenity vyžaduje komplikaci mechanismu podpory polí v překladači jazyků.

Práce s pamětí

Typickým způsobem implementace statického homogenního pole (ukládajícího data stejného typu) je alokace souvislého bloku paměti o objemu , kde  je velikost jednoho prvku a  jsou velikosti rozsahů indexů (tj. počet hodnot, které může nabývat odpovídající index). Při přístupu k prvku pole s indexem se adresa odpovídajícího  prvku  vypočítá jako Pořadí indexů ve vzorci pro výpočet adresy se může lišit. (Tento způsob odpovídá implementaci ve většině kompilátorů C ; ve Fortranu je pořadí indexů obrácené [2] ).

Adresa prvku s danou sadou indexů se tedy vypočítá tak, že přístupová doba ke všem prvkům pole je teoreticky stejná; mohou však ovlivnit různé hodnoty zpoždění odezvy od RAM k buňkám umístěným na různých paměťových prvcích, ale v praxi programování na vysoké úrovni jsou takové jemnosti až na vzácné výjimky zanedbávány.

Obvyklým způsobem implementace heterogenních polí je ukládat hodnoty samotných prvků samostatně a umístit ukazatele na tyto prvky do paměťového bloku pole (organizovaného jako běžné homogenní pole, popsané výše). Vzhledem k tomu, že ukazatele na hodnoty jakéhokoli typu mají tendenci mít stejnou velikost, je možné zachovat jednoduchý výpočet adresy, i když existuje další režie pro alokaci a přístup k hodnotám prvků.

Dynamická pole mohou používat stejný mechanismus rozložení jako statická pole, ale s určitou extra pamětí přidělenou pro rozšíření a přidání mechanismů pro změnu velikosti a přesun obsahu pole v paměti.

Dynamická a heterogenní pole lze také implementovat pomocí zásadně odlišných metod ukládání hodnot do paměti, například jednoduše nebo dvojitě propojených seznamů. Takové implementace mohou být flexibilnější, ale obvykle vyžadují další režii. Navíc obvykle nesplňují požadavek konstantní doby přístupu k prvku.

Poznámky

  1. Drot V. L., Novikov F. A. „Vysvětlující slovník moderní počítačové slovní zásoby“, Dimenze pole . Datum přístupu: 18. října 2012. Archivováno z originálu 3. července 2013.
  2. 1 2 Barteniev, 2000 .
  3. 1 2 Magariu, 1983 .
  4. Wirth, 1989 , 1.6 Array.
  5. Michael McMillan. Datové struktury a algoritmy s JavaScriptem  (anglicky) . - O'Reilly Media , 2014. - S. 30-32. — ISBN 978-1-4493-7396-2 .

Literatura

  • Wirth N. Algoritmy a datové struktury = Algoritmy a datová struktura. — M .: Mir, 1989. — 360 s. — ISBN 5-03-001045-9 .
  • Magariu N.A. Programovací jazyk APL. - M. : "Rozhlas a komunikace", 1983. - 96 s.
  • Barteniev O. V. Moderní Fortran. - 3. vyd., dodat. a revidováno .. - M . : Dialog-MEPhI, 2000. - 449 s.