Zaawansowane CPP/Ćwiczenia 10: Inteligentne wskaźniki: Różnice pomiędzy wersjami
Z Studia Informatyczne
Przejdź do nawigacjiPrzejdź do wyszukiwania
Nie podano opisu zmian |
Nie podano opisu zmian |
||
| Linia 1: | Linia 1: | ||
{{cwiczenie|1|| | {{cwiczenie|1|| | ||
Napisz testy sprawdzające działanie | Napisz testy sprawdzające działanie szablonu | ||
inteligentnego wskaźnika opartego na zliczaniu referencji. | inteligentnego wskaźnika opartego na zliczaniu referencji. | ||
}} | }} | ||
{{cwiczenie|2|| | {{cwiczenie|2|| | ||
Napisz klasę | Napisz klasę wytyczną do wskaźnika <code><nowiki>Ref_ptr</nowiki></code> opartą o | ||
listę referencji. | listę referencji. | ||
}} | }} | ||
Wersja z 14:45, 12 wrz 2006
Ćwiczenie 1
Napisz testy sprawdzające działanie szablonu inteligentnego wskaźnika opartego na zliczaniu referencji.
Ćwiczenie 2
Napisz klasę wytyczną do wskaźnika Ref_ptr opartą o
listę referencji.
Ćwiczenie 3
Napisz klasę wytyczną do wskaźnika ref_ptr opartą o licznik we wskazywanym obiekcie. Załóż, że obiekty wskazywane dziedziczą z klasy:
class Handle {
private:
size_t _count;
public:
Handle():_count(0){};
void add_ref() { ++_count;}
bool remove_ref() {--_count; return _count == 0;}
size_t count() const {return _count;};
};
Ćwiczenie 4
Zaimplementuj iterator pozwalający wkładać wartości na koniec kontenera.
Ćwiczenie 5
Zaimplementuj iterator realizujący przechodzenie po drzewie binarnym. Drzewo oparte jest o strukturę:
template<typename T> class binary_tree {
class node {
T _val;
node *_left;
node *_right;
}
node* _root;
}