Erich Gamma Ralph Johnson Richard Helm John Vlissides Addison-Wesley


 Это можно проверять на этапе компиляции, если объявить операторы new и delete закрытыми. Ре-



Download 6,32 Mb.
Pdf ko'rish
bet207/273
Sana02.03.2022
Hajmi6,32 Mb.
#479589
1   ...   203   204   205   206   207   208   209   210   ...   273
Bog'liq
Priemioop

1
 Это можно проверять на этапе компиляции, если объявить операторы new и delete закрытыми. Ре-
ализовывать их при этом не надо.


Паттерн Iterator
public:
IteratorPtr(Iterator* i): _i(i) { }
~IteratorPtr() { delete _i; }
Iterator* operator->() { return _i; }
Iterator& operator*!) { return *_i; }
private:
// запретить копирование и присваивание, чтобы
// избежать многократных удалений _i
IteratorPtr(const IteratorPtrk);
IteratorPtrk operator=(const IteratorPtrk);
private:
Iterator* _i;
};
IteratorPtr позволяет упростить код печати:
AbstractList* employees;
//
...
IteratorPtr iterator (employees->Create!terator () ) ;
PrintEmployees (*iterator) ;
а
 внутренний Listlterator.
В последнем примере рассмотрим, как можно было
бы реализовать внутренний или пассивный класс Listlterator. Теперь
итератор сам управляет итерацией и применяет к каждому элементу неко-
торую операцию.
Нерешенным остается вопрос о том, как параметризовать итератор той опе-
рацией, которую мы хотим применить к каждому элементу. C++ не поддер-
живает ни анонимных функций, ни замыканий, которые предусмотрены для
этой цели в других языках. Существует, по крайней мере, два варианта: пере-
дать указатель на функцию (глобальную или статическую) или породить под-
классы. В первом случае итератор вызывает переданную ему операцию в каж-
дой точке обхода. Во втором случае итератор вызывает операцию, которая
замещена в подклассе и обеспечивает нужное поведение.
Ни один из вариантов не идеален. Часто во время обхода нужно аккумули-
ровать некоторую информацию, а функции для этого плохо подходят — при-
шлось бы использовать статические переменные для запоминания состоя-
ния. Подкласс класса Iterator предоставляет удобное место для хранения
аккумулированного состояния - переменную экземпляра. Но создавать
подкласс для каждого вида обхода слишком трудоемко.
Вот набросок реализации второго варианта с использованием подклассов.
Назовем внутренний итератор ListTraverser:
template 
class ListTraverser {
public:
ListTraverser (List* aList) ;
bool Traverse () ;



Download 6,32 Mb.

Do'stlaringiz bilan baham:
1   ...   203   204   205   206   207   208   209   210   ...   273




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish