Obyektlarga ko‘rsatkichlar Obyektlar aniqlangandan so‘ng shu obyektlarga ko‘rsatkichlar belgilash
mumkin. Masalan:
complex A(5.2,2.7); complex* PA=&A;
Obyektning umumiy elementlariga murojaat uchun -> operatsiyani yoki ism almashtirish va nuqta operatsiyasidan foydalanish mumkin.
Usul tanasida obyekt maydonlariga murojaat kilinganda obyekt nomi ko‘rsatilmaydi. Usulga murojaat qilish dasturda uning nomini ko‘rsatish bilan bajariladi. Masalan:
Var
MyObject: TchildClass; y: Real;
Begin
. . . . . . . . . . . . . . .
MyObject. SecondProc; y:=MyObject.FirstFunc(3.14); End;
Usullar — sinf ichida ta’riflangan protsedura va funksiyalardir. Sinf tarkibiga usullarni chaqirish uchun zarur bo‘lgan ma’lumotlar saqlanuvchi maxsus jadvalga ilova kiradi.Usullar chaqirilganda chaqirgan obyektga ilova uzatiladi. Bu ilovaga usul ichida self so‘zi orqali murojaat qilish mumkin.
procedure TPerson.Tproc(Fore:Integer); begin
self.Fore:=Fore; end;
II BOB AMALIY QISM 2.1 Sinflar orasidagi munosabatlar Har bir sinfni ikkita muhim jihati mavjud: u arxitektura birligini moduli hisoblanadi,va u bir necha ma’lumotlar turlarini aniqlagan holda sermazmun tushunchaga ega. Dastur tizimi sinflari hammasi bir-biri bilan o‘zaro aniq bog‘lanishda bo‘ladi.
Obyektli dasturlash tizimida ikkita asosiy tur sinflarni o‘zaro bog‘lanishi aniqlangan.Birinchi bog‘lanish “Mijoz va Yetkazuvchi”, odatda mijoz bog‘lanishi deb ataladi yoki ichma-ich bog‘lanishda bo‘ladi. Ikkinchi bog‘lanish “Ota-onalar va vorislar” bu odatda vorislik deb nomlanadi.
Тa’rif 1. A va V sinflar “mijoz va yetkazuvchi” bog‘lanishida bo‘lsa, agar V sinfning maydoni A sinf obyekti bo‘lsa, A sinf V sinfning yetkazuvchisi deb nomlanadi, V sinfi A sinfning mijozi deb ataladi.
Тa’rif 2. A va V sinflar “Ota-onalar va vorislar” bog‘lanishida deyiladi, agar V sinf e’lon qilishda A sinf ota sinf sifatida ko‘rsatilgan bo‘lsa, V sinf A sinfning vorisi deb ataladi.
Ikkala bog‘lanish – vorislik va ichma-ich joylashganlik tranzitivlik xossasiga ega. Agar V sinf A sinf mijozi, va S sinf V sinfning mijozi, bo‘lsa S sinf A sinfning mijozi bo‘ladi. Agar V sinf A sinf vorisi bo‘lsa, S sinf V sinfning vorisi bщlsa S sinf A sinfning vorisi bo‘ladi.
Yuqoridagi 1 va 2 ta’riflar to‘g‘ridan to‘g‘ri mijoz va yetkazuvchi, vorislik munosabatlarini aniqlaydi (1-bosqich mijoz,1-bosqich yetkazuvchi va hokazo). Rekursiv tarzida shuni aniqlash mumkinki: to‘g‘ridan to‘g‘ri k-chi bosqichdagi mijoz k+1 bosqichdagi mijos bilan bog‘lanishda bo‘ladi. Vorislik bog‘lanishida, tabiiy tildagi tushunchalar qo‘llanadi. Тo‘g‘ridan to‘g‘ri bo‘lmagan vorislik ajdodlar va avlodlar bog‘lanishi deyiladi.
Agar sinfda boshqa sinf obyektlari mavjud bo‘lsa, unda, sinf a’zosi - konstruktor uchun parametri sinf konstruktori ta’rifida (lekin tavsifida emas) ko‘rsatiladi. A’zosi uchun konstruktor uning uchun parametrlar ro‘yxatini belgilovchi konstruktor bajarilgandan so‘ng chaqiriladi.
Misol:
class A
{ int i; public:
A(int ii) {i=ii;}
. . .
};
A sinfni o‘z ichiga kamrab olgan sinf:
class B
{ int k;
A member; public:
B(int ii, int kk): member(ii){k=kk;}
. . .
};
Boshqa a’zolar (agarda ular mavjud bo‘lsa) konstruktorlari uchun shuning singari parametrlarni belgilash mumkin:
class classdef { table members; table friends;
int no_of_members;
// ...
classdef(int size);
~classdef();
};
A’zolar uchun parametrlar ro‘yxati bir biridan vergul (ikkita nuqta emas) yordamida ajratiladi, ammo a’zolar uchun initsializatorlar ro‘yxatini ixtiyoriy tartibda belgilash mumkin:
classdef::classdef(int size)
: friends(size), members(size), no_of_members(size)
{
// ...
}
Konstruktorlar sinf tavsifida belgilangan tartibda chaqiriladi.
C++da aniq sinf do‘stlariga bu sinfning xususiy elementlariga murojaat etish imkonini beradi. C++ da bitta sinf yoki funksiya ikkinchi sinfga do‘stona sinfligini ko‘rsatish uchun friend kalit so‘zidan foydalanish va do‘stona sinf ismini ikkinchi sinf tavsifiga kiritish lozim.
Do‘stona funksiya va sinflarni ta’riflash:
friend friend
Masalan, quyidagi book sinfi librarian sinfini o‘ziga do‘stona sinf deb belgilagan:
class book
{ char title [64] ; char author[64];
char catalog[64]; public:
book (char *, char *, char *); void show_book(void); friend librarian;
};
Shuning uchun librarian sinf obyektlari book sinfning xususiy elementlariga, nuqta operatoridan foydalangan holda, to‘g‘ridan to‘g‘ri murojaat etishi mumkin:
class librarian
{
public:
void change_catalog(book *, char *);
char *get_catalog(book);
};
void librarian::change_catalog(book *this_book, char *new_catalog)
{
strcpy(this_book->catalog, new_catalog);
}
char *librarian: :getcatalog(book this_book)
{ static char catalog[64]; strcpy(catalog, this_book.catalog); return(catalog) ;
}
Ko‘rib turganimizdek dastur librarian klassining change_catalog funksiyasiga book obyektini adres orqali bermoqda. Bu funksiya klassning book elementini o‘zgartirgani uchun, dastur parametrni adres orqali uzatishi va undan so‘ng ushbu klass elementiga murojat uchun ko‘rsatkich ishlatmog‘i lozim. Book klassi aniqlanishidan friend operatori o‘chirib yuborilsa C++ kompilyatori har gal book klassi xususiy ma’lumotlariga murojatda sintaksik xato xaqida xabar chiqaradi.
Agarda bir nechta sinf funksiyalariga boshqa sinfning xususiy ma’lumotlariga murojaat qilish kerak bo‘lsa, u holda C++ do‘stona sinfning faqatgina belgilangan funksiyalari xususiy elementlarga murojaat etishiga imkoniyat beradi. A’zolarga murojaat etishda this dan foydalanish ortiqcha. Asosan this bevosita ko‘rsatkichlar bilan manipulyatsiya qilish uchun a’zo funksiyalarini yaratilishida foydalaniladi. Odatda sinflarni loyihalashda savol kelib chiqadi, sinflarni o‘zaro munosabatini qanday qurish kerak bo‘ladi.Ikkita oddiy sinflarga misol ko‘ramiz – Square va Rectangle, ular kvadrat va to‘g‘rito‘rtburchaklardir. Shunisi tushunarliki bu Ko‘rib turganimizdek friend operatorlari xususiy elementlarga murojat qiluvchi hamma do‘st funksiyalarini to‘liq prototiplarini o‘z ichiga oladi.
Agar dastur bir sinfdan boshqasiga murojaat qilsa va sinflar aniqlanish tartibi noto‘g‘ri bo‘lsa sintaksik xatoga duch kelish mumkin. Bizning holda book klassi librarian klassida e’lon qilingan funksiyalar prototiplariga murojat qilmoqda. Shuning uchun librarian klassi aniqlanishi book klassi aniqlanishidan oldin kelishi kerak, biroq librarian klassi book klassiga murojat qilmoqda:
Har qaysi obyekt sinf maydonining o‘z nusxasiga ega. Sinf usuli xotirada bitta nusxada bo‘ladi va hamma obyektlar bilan birgalikda ishlatiladi. Shuning uchun usullarni maydonlar bilan ishini tashkil etishda chaqirilayotgan obyekt uchun ta’minlanishiga e’tibor berish kerak. Bu esa yashirin this parametrini funksiyaga o‘zatishni ta’minlaydi. this ko‘rsatkichi noaniq ravishda usulning ichkarisida foydalaniladi. Aniq holatda esa bu ko‘rsatkich usuldagi ko‘rsatkichni hisoblashda Yana ikkita sinfga misol – Car va Person, ya’ni mashina va inson. Bu sinflar bilan Person_of_Car ya’ni mashina egasi sinfi qanday aloqada bo‘lishi mumkin? Bu ikki sinf bilan vorislik bog‘lanishida bo‘lishi mumkinmi? Sinflarni loyihalash bilan bog‘liq bu savollarga javob topish uchun shuni nazarda tutish kerakki, “mijoz- yetkazuvchi” bog‘lanishi “ega” (“has”) bog‘lanishini, vorislik bog‘lanishi esa “bir xil” (“is a”) bog‘lanishi tushunchalarini ifodalaydi. Square va Rectangle sinflari misoli tushunarli, har bir obyekt kvadrat to‘g‘rito‘rtburchakdir, shuning uchun bu sinflar o‘rtasida vorislik bog‘lanishi ifodalanadi, va Rectangle sinfi ota-onalar sinfini ifodalaydi. Square sinfi uning o‘g‘lidir. Mashina egasi mashinaga ega va insondir. Shuning uchun Person_of_Car sinfi Car sinfning mijozi bo‘lib hisoblanadi va Person sinfning vorisidir.