C ++ dynamické přidělování polí s příkladem

Obsah:

Anonim

Co je to dynamické pole?

Dynamické pole je docela podobné běžnému poli, ale jeho velikost je během běhu programu upravitelná. Prvky DynamArray zabírají souvislý blok paměti.

Po vytvoření pole nelze jeho velikost změnit. Dynamické pole je však jiné. Dynamické pole může zvětšit svou velikost i po vyplnění.

Během vytváření pole je mu přiděleno předem určené množství paměti. To u dynamického pole neplatí, protože v případě potřeby zvětší velikost paměti o určitý faktor.

V tomto výukovém programu C ++ se naučíte

  • Co je to dynamické pole?
  • Faktory ovlivňující výkon dynamických polí
  • Nové klíčové slovo
  • Inicializace dynamicky přidělených polí
  • Změna velikosti polí
  • Dynamické mazání polí

Faktory ovlivňující výkon dynamických polí

Počáteční velikost pole a jeho růstový faktor určují jeho výkon. Všimněte si následujících bodů:

  1. Pokud má pole malou velikost a malý růstový faktor, bude udržovat realokaci paměti častěji. Tím se sníží výkon pole.
  2. Pokud má pole velkou velikost a velký růstový faktor, bude mít obrovskou část nevyužité paměti. Z tohoto důvodu může operace změny velikosti trvat déle. Tím se sníží výkon pole.

Nové klíčové slovo

V C ++ můžeme vytvořit dynamické pole pomocí nového klíčového slova. Počet položek, které mají být přiděleny, je uveden v dvojici hranatých závorek. Název typu by měl předcházet. Bude přidělen požadovaný počet položek.

Syntax:

Nové klíčové slovo má následující syntaxi:

pointer_variable = new data_type;

Pointer_variable je název proměnné ukazatele.

Data_type musí být platný datový typ C ++.

Klíčové slovo pak vrátí ukazatel na první položku. Po vytvoření dynamického pole jej můžeme odstranit pomocí klíčového slova delete.

Příklad 1:

#includeusing namespace std;int main() {int x, n;cout << "Enter the number of items: << "\n";cin >>n;int *arr = new int(n);cout << "Enter " << n << " items" << endl;for (x = 0; x < n; x++) {cin >> arr[x];}cout << "You entered: ";for (x = 0; x < n; x++) {cout << arr[x] << " ";}return 0;}

Výstup:

Zde je snímek obrazovky s kódem:

Vysvětlení kódu:

  1. Chcete-li používat jeho funkce, zahrňte do našeho programu soubor záhlaví iostream.
  2. Zahrňte do našeho programu std namespace, abyste mohli používat jeho třídy, aniž byste jej volali.
  3. Zavolejte funkci main (). Logika programu by měla být přidána do těla funkce.
  4. Deklarujte dvě celočíselné proměnné x a n.
  5. Vytiskněte na konzoli text, který uživatele vyzve k zadání hodnoty proměnné n.
  6. Přečíst vstup uživatele z klávesnice a přiřadit jej k proměnné n.
  7. Deklarujte matici, která pojme celkem n celých čísel a přiřadí ji proměnné ukazatele * arr.
  8. Vytiskněte zprávu s výzvou k zadání n počtu položek.
  9. Pomocí smyčky for vytvořte proměnnou smyčky x pro iteraci položek zadaných uživatelem.
  10. Přečtěte si prvky zadané uživatelem a uložte je do pole pole.
  11. Konec těla smyčky for.
  12. Vytiskněte nějaký text na konzoli.
  13. Pomocí smyčky for vytvořte smyčkovou proměnnou x k iteraci nad položkami pole.
  14. Vytiskněte na konzole hodnoty obsažené v poli s názvem arr.
  15. Konec těla smyčky for.
  16. Po úspěšném dokončení musí program vrátit hodnotu.
  17. Konec těla funkce main ().

POZNÁMKA: Ve výše uvedeném příkladu může uživatel během běhu zadat libovolnou velikost pole. To znamená, že velikost pole je určena za běhu .

Inicializace dynamicky přidělených polí

Je snadné inicializovat dynamické pole na 0.

Syntax:

int *array{ new int[length]{} };

Ve výše uvedené syntaxi délka označuje počet prvků, které se mají přidat do pole. Protože musíme inicializovat pole na 0, mělo by to zůstat prázdné.

Můžeme inicializovat dynamické pole pomocí seznamu inicializátorů. Pojďme vytvořit příklad, který to ukazuje.

Příklad 2:

#include using namespace std;int main(void) {int x;int *array{ new int[5]{ 10, 7, 15, 3, 11 } };cout << "Array elements: " << endl;for (x = 0; x < 5; x++) {cout << array[x] << endl;}return 0;}

Výstup:

Zde je snímek obrazovky s kódem:

Vysvětlení kódu:

  1. Chcete-li používat jeho funkce, zahrňte do našeho programu soubor záhlaví iostream.
  2. Zahrňte do našeho programu standardní obor názvů, abyste mohli používat jeho třídy, aniž byste jej volali.
  3. Zavolejte funkci main (). Logika programu by měla být přidána do těla funkce.
  4. Deklarujte celočíselnou proměnnou s názvem x.
  5. Deklarujte dynamické pole s názvem pole pomocí seznamu inicializátorů. Pole pojme 5 celočíselných prvků. Všimněte si, že jsme nepoužili operátor mezi délkou pole a seznamem inicializátoru.
  6. Vytiskněte nějaký text na konzoli. Endl je klíčové slovo C ++, což znamená koncový řádek. Přesune kurzor na další větu.
  7. K opakování prvků pole použijte smyčku for.
  8. Vytiskněte obsah pole s názvem pole na konzoli.
  9. Konec těla smyčky for.
  10. Po úspěšném dokončení musí program vrátit hodnotu.
  11. Konec těla funkce main ().

Změna velikosti polí

Délka dynamického pole se nastavuje během doby přidělování.

C ++ však nemá vestavěný mechanismus změny velikosti pole, jakmile bylo přiděleno.

Tuto výzvu však můžete překonat dynamickým přidělením nového pole, kopírováním přes prvky a poté vymazáním starého pole.

Poznámka: tato technika je náchylná k chybám, proto se jí snažte vyhnout.

Dynamické mazání polí

Dynamické pole by mělo být odstraněno z paměti počítače, jakmile je splněn jeho účel. K tomu vám pomůže prohlášení o odstranění. Uvolněné místo v paměti lze poté použít k uložení další sady dat. I když však neodstraníte dynamické pole z paměti počítače, po ukončení programu bude automaticky odstraněno.

Poznámka:

Chcete-li odstranit dynamické pole z paměti počítače, měli byste místo odstranění použít delete []. [] Dává CPU pokyn k odstranění více proměnných namísto jedné proměnné. Použití odstranění namísto odstranění [] při práci s dynamickým polem může mít za následek problémy. Mezi příklady takových problémů patří úniky paměti, poškození dat, pády atd.

Příklad 3:

#includeusing namespace std;int main() {int x, n;cout << "How many numbers will you type?" << "\n";cin >>n;int *arr = new int(n);cout << "Enter " << n << " numbers" << endl;for (x = 0; x < n; x++) {cin >> arr[x];}cout << "You typed: ";for (x = 0; x < n; x++) {cout << arr[x] << " ";}cout << endl;delete [] arr;return 0;}

Výstup:

Zde je snímek obrazovky s kódem:

Vysvětlení kódu:

  1. Zahrňte soubor záhlaví iostream do našeho programu, abyste mohli využívat jeho funkce.
  2. Zahrňte do našeho programu std namespace, abyste mohli používat jeho třídy, aniž byste jej volali.
  3. Zavolejte funkci main (). Logika programu by měla být přidána do těla funkce.
  4. Deklarujte dvě proměnné x a n celočíselného datového typu.
  5. Vytiskněte nějaký text na konzoli. Text požádá uživatele, aby uvedl počet čísel, která zadá.
  6. Čtení vstupu uživatele z klávesnice. Vstupní hodnota bude přiřazena proměnné n.
  7. Deklarovat proměnnou ukazatele * arr. Array pole si vyhradí část paměti pro uložení celkem n celých čísel.
  8. Na konzole vytiskněte zprávu s výzvou k zadání n čísel.
  9. Vytvořte smyčku for a smyčku proměnnou x, abyste iterovali nad čísly zadanými uživatelem.
  10. Přečtěte si čísla zadaná uživatelem a uložte je do pole Arr.
  11. Konec těla smyčky for.
  12. Vytiskněte nějaký text na konzoli.
  13. Použijte smyčku pro a smyčku proměnné x k iteraci obsahu pole Arr.
  14. Vytiskněte hodnoty pole Arr na konzole.
  15. Konec těla smyčky for.
  16. Vytiskněte na konzole prázdný řádek.
  17. Uvolněte paměť pole Arr.
  18. Po úspěšném dokončení program vrátí hodnotu.
  19. Konec těla funkce main ().

Souhrn:

  • Pravidelná pole mají pevnou velikost. Jakmile je deklarována jejich velikost, nemůžete je upravit.
  • U těchto typů polí se velikost paměti určuje během doby kompilace.
  • Dynamická pole se liší. Jejich velikosti lze měnit za běhu.
  • V dynamických polích je velikost určena za běhu.
  • Dynamická pole v C ++ jsou deklarována pomocí nového klíčového slova.
  • V hranatých závorkách určujeme počet položek, které mají být uloženy v dynamickém poli.
  • Po dokončení pole můžeme uvolnit paměť pomocí operátoru odstranění.
  • Pomocí operátoru odstranění pomocí [] uvolněte paměť všech prvků pole.
  • Odstranění bez [] uvolní paměť pouze jednoho prvku.
  • Neexistuje žádný integrovaný mechanismus pro změnu velikosti polí C ++.
  • K inicializaci pole pomocí inicializátoru seznamu nepoužíváme operátor .