• Heap taqsimlanishi
  • Ehtiyotkor Boshqaruv
  • Stack asosli Xotira Boshqaruv
  • Xotirani Dinamik Taqsimlash




    Download 5,4 Mb.
    bet4/5
    Sana15.05.2024
    Hajmi5,4 Mb.
    #235102
    1   2   3   4   5
    Bog'liq
    1-mustaqil ish tizimli dasturlash

    Xotirani Dinamik Taqsimlash
    Moslashuvchanlik
    Dinamik xotira ajratish dasturlarga zarur bo'lgan o'zgaruvchan o'lchamdagi ma'lumot strukturalarini yaratish va bo'shatish imkoniyatini beradi. Bu moslashuvchanlik o'zgaruvchan o'lchamdagi ma'lumot strukturasi talab qiluvchi yoki ma'lum va o'zgaruvchan xotira talablari bilan ishlash zarurati bo'lgan dasturlar uchun muhimdir. Xotira ajratish orqali, dasturlar statistik tariflangan xotira o'lchamlari bilan cheklanmagan holda tizim resurslarini samarali ishlatishlari mumkin bo'ladi.
    Heap taqsimlanishi
    Dinamik xotira ajratish odatda heap, stekdan ajratilgan xotira mintaqasi, qo'llanadi. Heap elastik ochiq xotira maydoni bilan ta'minlanadi va dasturlar on-the-fly xotira ajratish va bo'shatish imkonini beradi. Ushbu xususiyat stekning cheklanmagan o'lchamli xotiralariga ega bo'lgan murakkab ma'lumot strukturasi, masalan, bog'langan ro'yxatlar, daraxtlar va hash jadvali kabi, yaratish va boshqarishga imkon beradi.
    Ehtiyotkor Boshqaruv
    Dinamik xotira ajratish kuchli imkoniyatlarni taklif etishiga qaramay, xotiraning tashqi qo'l bilan yoki parchalanish bilan bog'liq umumiy muammolarni oldini olish uchun ehtiyotkor boshqaruv talab qiladi. Dasturchilar xotirani ehtiyotkorlik bilan ajratish va bo'shatishlarni amalga oshirishlari, eng yaxshi amaliyotlarni o'rganishlari va xotira profilayzerlar kabi vositalardan foydalanishlari kerak, bu esa samarali va xato-freeng xotira foydalanishini ta'minlash uchun muhimdir. Xotira boshqaruvining to'g'ridan-to'g'ri amalga oshirilishi dinamik dasturlarning barqarorlik va ishlaydiganlikni saqlash uchun muhimdir.
    Stack asosli Xotira Boshqaruv
    Xotira boshqaruv sohasida stack asosli qarash usuli, xotira ajratish va bo'shatishni samarali amalga oshirish uchun oxirgi kiritilgan birinchi chiqish (LIFO) prinsipi bilan foydalanadigan asosiy strategiya hisoblanadi. Stack, funksiya chaqirish ma'lumotlarini, mahalliy o'zgaruvchilarni va vaqtincha ma'lumotlarni saqlash uchun ishlatiladigan xotira maydonidir. U holda yangi ma'lumotlar tug'ridan tug'ri yuqori qismini qo'shib (push) va undan o'chirib (pop) olib tashlanadi, agar ularga qo'yilishi kerak bo'lmasa.
    Funksiya chaqirilganda, uning parametrlari, qaytish manzili va mahalliy o'zgaruvchilar stackga qo'yiladi. Funksiya ishlatilib bolinganda, ushbu elementlar stackdan ochiribb tashlanadi, bu ular tomonidan egallangan xotirani qayta ishlatish imkonini beradi. Ushbu mexanizm xotira resurslarining nazorat qilinadigan va etkazib beruvchisini pasaytiradigan tartibda foydalanishini ta'minlaydi, bu esa xotira kechishlari va fraksiyalanishining riskini kamaytiradi.
    Stack asosli qarash usuli, kichik, o'zgarmas o'lchamdagi ma'lumot strukturasi va qisqa muddatli o'zgaruvchilar uchun qulay va tezroq xotira boshqarish yo'li taqdim etadi. U xotirani boshqarishning oddiy va tez yo'li sifatida xizmat qiladi, chunki xotirani ajratish va ko'chirish amaliyoti bir marta (push yoki pop) bilan amalga oshirilishi mumkin. Biroq, stack o'lchami chegaralanadi va katta yoki dinamik o'lchamdagi ma'lumot strukturasi uchun qo'llaniladigan ko'paytirilgan xotira boshqaruv usullariga mos kelmasligi mumkin.

    Download 5,4 Mb.
    1   2   3   4   5




    Download 5,4 Mb.