Dinamik massivlar bilan ishlash




Download 29,83 Kb.
bet2/2
Sana15.05.2024
Hajmi29,83 Kb.
#235351
1   2
Bog'liq
Mustaqil ish

Dinamik massivlar bilan ishlash.
Statik massivlarning kamchiliklari shundaki, ularning o`lchamlari oldindan ma`lum bo`lishi kerak, bundan tashqari bu o`lchamlar berilganlarga ajratilgan xotira segmentining o`lchami bilan chegaralangan . Ikkinchi tomondan, yetarlicha kata o`lchamdagi massiv e`lon qilinib, konkret masala yechilishida ajratilgan xotira to`liq ishlatilmasligi mumkin. Bu kamchiliklar dinamik massivlardan foydalanish orqali bartaraf etiladi, chunki ular programma ishlashi jarayonida kerak bo`lgan o`lchamdagi massivlarni yaratish va zarurat qolmaganda yo`qotish imkoniyatini beradi.
Dinamik massivlarga xotira ajratish uchun malloc(), calloc() funksiyalaridan yoki neu operatoridan foydalanish mumkin. Dinamik obyektga ajratilgan xotirani bo`shatish uchun delete operatori ishlatiladi
Yuqorida qayd qilingan funksiyalar <> kutubxonasida joylashgan.
Malloc() funksiyasining sintaksisi
Void * malloc(size_t size);
Ko`rinishida bo`lib , u hotiraning uyum qismidan size bayt o`lchamdagi uzluksiz sohani ajratadi. Agar xotira ajratish
muvaffaqiyatli bo`lsa, malloc() funksiyasi ajratilgan sohaning boshlanish adresini qaytaradi. Talab qilingan xotirani ajratish muvaffaqiyatli bo`lsa , funksiya NULL qiymatni qaytaradi.
Sintaksisdan ko`rinib turibdiki, funksiya void turidagi qiymat qaytaradi.
Amalda esa konkret turdagi obyekt uchun xotira ajratish zarur bo`ladi. Buning uchun void konkret turga keltirish texnologiyasidan foydalaniladi. Masalan , butun turdagi uzunligi 3 ga teng massivga joy ajratishni quyidagicha amalga oshirish mumkin:
Int * pint=(int*)malloc(3*sizeof(int));
Calloc() funksiyasi malloc funksiyasidan farqli ravishda massiv uchun joy ajratishdan tashqari massiv elementlarini 0 qiymati bilan initsializatsiya qiladi.
Bu funksiya sintaksisi .
Void * calloc(size_t num, size_ t size);
Ko`rinishida bo`lib , num parametri ajratilgan sohada nechta element borligini, size xar bir element o`lchamini bildiradi.
Free() xotirani bo`shatish funksiyasi o`chiriladigan xotira bo`lagiga ko`rsatkich bo`lgan yagona parametrga ega bo`ladi:
Void free(void* block);
Free() funksiyasi parametrining void turida bo`lishi ixtiyoriy turdagi xotira bo`lagini ochirish imkonini beradi .
Quyidagi programmada 10 ta butun sondan iborat dinamik massiv yaratish, unga qiymat berish va o`chirish amallari bajarilgan.
#include #include int main()
{
int * pvector;
if ((pvector=(int*)malloc(10*sizeof(int)))==NULL) {
Cout<<”xotira yetarli emas!!!”;
Return 1;
}
// ajratilgan xotira soxasini to`ldirish
For (int i=0; i<10; i++) *(pvektor+i)=I;
// vector elementlarini hop etish
For (int i=0; i<10; i++) cout<<*(pvector+i)<// ajratilgan xotira bo`lagini qaytarish (o`chirish)
Free(pvector);
Return 0;
}
new operatori yordamida ,massivga hotira ajratishda obyrkt turidan keyin kvadrat qavs ichida obyektlar soni ko`rsatiladi.
Masalan , butun turdagi 10 ta sondan iborat massivga joy ajratish uchun pVector=new int[10];
ifodasi yozilishi kerak. Bunga qarama – qarshi ravishda , bu usulda ajratilgan xotirani bo`shatish uchun delete [] pVector;
ko`rsatmasini berish kerak bo`ladi;
Ikki o`lchamli dinamik massivni hosil qilish uchun int **a; ko`rinishidagi <> ishlatiladi.
Boshqa massiv satrlari soniga qarab ko`rsatkichlar massiviga dinamik xotiradan joy ajratish kerak:
A=new int *[m] // bu yerda m massiv satrlar soni
Keyin , xar bir satr uchun takrorlash operatori yordamida xotira ajratish va ularning boshlang`ich adreslarini a massiv elementlariga joylashtirish zarur bo`ladi:
For (int i=0; iShuni qayd etish kerakki , dinamik massivning har bir satri xotiraning turli joylarida joylashishi mumkin.
Ikki o`lchamli massivni o`chirishda oldin massivning har bir elementi (satri), so`ngra massivning o`zi yo`qotiladi.
For (i=0; i

Xulosa

Demak, massiv – bu fiksirlangan miqdordagi ayrim qiymatlarning (massiv elementlarining) tartiblangan majmuasidir. Barcha elementlar bir xil turda bo‘lishi kerak va bu tur element turi yoki massiv uchun tayanch tur deb nomlanadi. Yuqoridagi keltirilgan misolda Reyting – haqiqiy turdagi vektor deb nomlanadi.
Programmada ishlatiladigan har bir konkret massiv o‘zining individual nomiga ega bo‘lishi kerak. Bu nomni to‘liq o‘zgaruvchi deyiladi, chunki uning qiymati to‘liq bir massivning o‘zi bo‘ladi. Massivning har bir elementi massiv nomi, hamda kvadrat qavsga olingan va element selektori deb nomlanuvchi indeksni ko‘rsatish orqali oshkor ravishda belgilanadi. Murojaat sintaksisi:
[]
Bu ko‘rinishga xususiy o‘zgaruvchi deyiladi, chunki uning qiymati massivning alohida elementidir, Bizning misolda Reyting massivining alohida komponentalariga Reyting[1], Reyting[2],..., Reyting[N] xususiy o‘zgaruvchilar orqali murojaat qilish mumkin. Boshqacha bu o‘zgaruvchilarni indeksli o‘zgaruvchilar deyiladi.
Foydalanilgan adabiyotlar:

1. T.A.Maxarov Dasturlash asoslari. O’quv qo’llanma. T.:2019 yil.


2. S.Eshtemirov, F.M.Nazarov Algoritmlash va dasturlash asoslari. O’quv qo’llanma. Samarqand. 2019 yil.
3. Mamajanov R.Y. C++ dasturlash tili. O’quv-uslubiy qo’llanma. Denov. 2020 yil.
Download 29,83 Kb.
1   2




Download 29,83 Kb.