Dynaaminen muistin allokointi on menetelmä tietokoneen RAM -muistin varaamiseksi ohjelman objekteille, jossa muistin varaaminen objektille suoritetaan ohjelman suorituksen aikana .
Dynaamisella muistin allokoinnilla objektit sijoitetaan ns. " kasa " ( eng. heap ): objektia rakennettaessa ilmoitetaan objektille pyydetyn muistin koko, ja onnistuessaan varattu muistialue "poistetaan" suhteellisesti " keosta ", jolloin siitä tulee ei ole käytettävissä myöhempien muistinvaraustoimintojen aikana. Merkityksellisesti päinvastainen operaatio on jonkin objektin aiemmin varaaman muistin vapauttaminen: vapautunut muisti, myös ehdollisesti sanottuna, palautetaan " kasaan " ja tulee saataville myöhemmissä muistinvarausoperaatioissa.
Kun ohjelmaan luodaan uusia objekteja, käytettävissä olevan muistin määrä vähenee. Tästä syystä on jatkuvasti vapautettava aiemmin varattu muisti. Ihanteellisessa tilanteessa ohjelman pitäisi vapauttaa kokonaan kaikki työhön tarvittava muisti. Analogisesti tämän kanssa jokaisen aliohjelman ( menettelyn tai funktion ) on varmistettava kaiken suorituksen aikana varatun muistin vapauttaminen. Virheellinen muistinhallinta johtaa ns. " vuotoja " muistista, kun varattu muisti ei vapaudu. Useat muistivuodot voivat kuluttaa kaiken RAM-muistin ja häiritä käyttöjärjestelmää.
Toinen ongelma on muistin pirstoutumisen ongelma. Muistin varaaminen tapahtuu lohkoissa - jatkuvissa RAM-osissa (siis jokainen lohko on muutama peräkkäinen tavu ). Jossain vaiheessa kasassa ei ehkä yksinkertaisesti ole sopivan kokoista lohkoa, ja vaikka vapaata muistia olisi tarpeeksi objektin sijoittamiseen, muistin varaustoiminto epäonnistuu.
Muistin dynaamisen varauksen hallintaan käytetään "roskankerääjää" - ohjelmaobjektia, joka valvoo muistin varausta ja varmistaa sen oikea-aikaisen vapauttamisen. Roskankerääjä myös varmistaa, että vapaat lohkot ovat maksimikokoisia, ja tarvittaessa eheyttää muistin.
C - ohjelmointikielellä on seuraavat toiminnot dynaamiseen muistin varaamiseen vakiokirjastossa :
C ++ :ssa on kaksi operaattoria:
Object Pascalilla on kaksi operaattoria: