Różnice między wybraną wersją a wersją aktualną.
Both sides previous revision Previous revision Next revision | Previous revision Next revision Both sides next revision | ||
timer [2009/04/18 20:47] lucas |
timer [2009/04/18 22:56] lucas |
||
---|---|---|---|
Linia 2: | Linia 2: | ||
**Łukasz Dobrodziej T-TIZ** | **Łukasz Dobrodziej T-TIZ** | ||
+ | ===== Wstęp ===== | ||
+ | Biblioteka Timer zapewnia trzy klasy, które umożliwiają kontrolę czasu - klasę ''timer'' do mierzenia czasu, który upłynął od danej chwili, klasę ''progress_timer'' do raportowania czasu oraz klasę ''progress_display'' do wyświetlania wskaźnika postępu. Klasy są wyposażone w obsługę wyjątków np. konstruktory mogą rzucić ''std::bad_alloc''. W praktyce rzucanie wyjątków przez obiekty tych klas jest mało prawdopodobne. | ||
- | ===== Wstęp ===== | ||
- | |||
- | Biblioteka Timer zapewnia trzy klasy, które umożliwiają kontrolę czasu - klasę ''timer'' do mierzenia czasu, który upłynął od danej chwili, klasę ''progress_timer'' do raportowania czasu oraz klasę ''progress_display'' do wyświetlania wskaźnika postępu. Klasy są wyposażone w obsługę wyjątków np. konstruktory mogą rzucić std::bad_alloc. W praktyce rzucanie wyjątków przez obiekty tych klas jest mało prawdopodobne. | ||
===== Klasa timer ===== | ===== Klasa timer ===== | ||
Linia 38: | Linia 37: | ||
</code> | </code> | ||
- | |||
===== Klasa progress_display ===== | ===== Klasa progress_display ===== | ||
Linia 46: | Linia 44: | ||
* **''expected_count()''** zwraca wartość docelową, podaną podczas kontrukcji obiektu. | * **''expected_count()''** zwraca wartość docelową, podaną podczas kontrukcji obiektu. | ||
* **''restart(unsigned long expected_count)''** ustawia nową wartość docelową, zeruje licznik. | * **''restart(unsigned long expected_count)''** ustawia nową wartość docelową, zeruje licznik. | ||
- | Klasa ma przeładowane operatory ''++'' i ''+='', które służą do zwiększania licznika (i jeżeli to konieczne dorysowania odpowiedniego znaku postępu). Dodatkowo przy pomocy konstruktora możemy zmienić miejsce wyświetlania paska postępu operacji oraz jego formę. Deklaracja konstruktora ma następującą postać: | + | Klasa ma przeładowane operatory ''++'' i ''+='', które służą do zwiększania licznika (i jeżeli to konieczne dorysowania odpowiedniego znaku postępu). Dodatkowo przy pomocy konstruktora możemy zmienić miejsce wyświetlania paska postępu operacji oraz możemy dodać tytuł dla każdego wiersza. Deklaracja konstruktora ma następującą postać: |
<code cpp> | <code cpp> | ||
progress_display( unsigned long expected_count, | progress_display( unsigned long expected_count, | ||
- | std::ostream& os, // os jest podpowiedzią, może być zignorowany | + | std::ostream& os, // os jest sugestia, moze byc zignorowany |
const std::string & s1 = "\n", | const std::string & s1 = "\n", | ||
const std::string & s2 = "", | const std::string & s2 = "", | ||
Linia 57: | Linia 55: | ||
Przykład użycia: | Przykład użycia: | ||
<code cpp> | <code cpp> | ||
- | progress_display show_progress( big_map.size() ); //inicjalizacja obiektu, zdefiniowanie wartości docelowej | + | progress_display show_progress( big_map.size() ); //inicjalizacja obiektu, zdefiniowanie wartosci docelowej |
for ( big_map_t::iterator itr = big_map:begin(); | for ( big_map_t::iterator itr = big_map:begin(); | ||
itr != big_map.end(); ++itr ) | itr != big_map.end(); ++itr ) | ||
Linia 72: | Linia 70: | ||
************************************ | ************************************ | ||
</code> | </code> | ||
+ | |||
+ | ===== Kod z przykładowym wykorzystaniem ===== | ||
+ | {{timer.cpp}} | ||
| |