Mavzu: Shablon funksiyalar yaratish va ulardan foydalanish


template< int size > class IntegerArray



Yüklə 17,05 Kb.
səhifə3/4
tarix13.12.2023
ölçüsü17,05 Kb.
#175250
1   2   3   4
Mavzu Shablon funksiyalar yaratish va ulardan foydalanish-fayllar.org

template< int size >
class IntegerArray
{int Array[ size ];
/* ... */};
shablon< int size > // Shablon prototipi
void PrintArray( IntegerArray< size > massiv ) { /* ... */ } // Shablon chaqiruvi
// Shablon ob'ektidan foydalanish
IntegerArray<20>ia;
PrintArray(ia);
Shablondan foydalanishni osonlashtirish va yuzaga kelishi mumkin bo'lgan xatolarni oldini olish uchun tilga xulosa chiqarish qoidalari kiritiladi, masalan, belgilar qatorini saralash uchun sort< int > dan foydalanishga urinish.
Agar shablon parametrini bir nechta argumentlardan chiqarish mumkin bo'lsa, unda xulosaning natijasi ushbu argumentlarning barchasi uchun aynan bir xil bo'lishi kerak. Masalan, quyidagi qo'ng'iroqlar noto'g'ri:

min (0, 'a');


min (7, 7.0);
Shablonlardagi xatolar
Shablonni ishlatishdan oldin maxsus shablon parametrlaridan foydalanish bilan bog'liq xatolarni aniqlab bo'lmaydi. Masalan, min shablonning o'zi xatosiz, lekin uni '<' operatori aniqlanmagan turlar bilan ishlatish xatolikka olib keladi:
struct A
{
int a;
};
A obj1, obj2;
min( obj1, obj2 );
Agar shablonni birinchi marta ishlatishdan oldin '<' operatsiyasini kiritsangiz, xatolik yo'qoladi. C++ da shablonlarning moslashuvchanligi shunday namoyon bo'ladi:
friend inline bool operator< ( const A& a1, const A& a2 ) { return a1.a < a2.a; }
min( obj1, obj2 );

Sinf shablonlar


Butun sonlarning bog'langan ro'yxatini amalga oshiradigan sinfda ro'yxatga yangi element qo'shish va kerakli elementni qidirish algoritmlari ro'yxat elementlarining butun son ekanligiga bog'liq emas. Xuddi shu algoritmlar belgilar, satrlar, sanalar, o'yinchilar sinflari va boshqalar ro'yxatiga nisbatan qo'llaniladi.
template< class T >
class List
{
/* ... */
public:
void Add(
Yüklə 17,05 Kb.

Dostları ilə paylaş:
1   2   3   4




Verilənlər bazası müəlliflik hüququ ilə müdafiə olunur ©azkurs.org 2024
rəhbərliyinə müraciət

gir | qeydiyyatdan keç
    Ana səhifə


yükləyin