reklama - zainteresowany?

Język C++ i przetwarzanie współbieżne w akcji - Helion

Język C++ i przetwarzanie współbieżne w akcji
ebook
Autor: Anthony Williams
Tytuł oryginału: C++ Concurrency in Action: Practical Multithreading
Tłumaczenie: Mikołaj Szczepaniak
ISBN: 978-83-246-7140-3
stron: 576, Format: ebook
Data wydania: 2013-06-07
Księgarnia: Helion

Cena książki: 44,50 zł (poprzednio: 89,00 zł)
Oszczędzasz: 50% (-44,50 zł)

Dodaj do koszyka Język C++ i przetwarzanie współbieżne w akcji

Tagi: C++ - Programowanie | programowanie-kupon

Odkryj wszystkie tajemnice wielowÄ…tkowych aplikacji!

Współbieżne przetwarzanie danych to największe wyzwanie dla programisty. Na każdym kroku czyhają na niego najbardziej wymyślne pułapki, a wykrycie pomyłki stanowi nie lada wyzwanie. Każdy programista wzdryga się na samą myśl o implementacji wielowątkowych rozwiązań. Nie musi tak być!

Dzięki tej książce poradzisz sobie z większością zadań i zwinnie ominiesz zastawione pułapki. W trakcie lektury dowiesz się, jak zidentyfikować zadania, w których zastosowanie współbieżności ma sens, oraz jak zarządzać wątkami. Ponadto nauczysz się chronić współdzielone dane oraz synchronizować współbieżne operacje. Duży nacisk został tu położony na zagadnienia związane z projektowaniem współbieżnych struktur danych oraz kodu. Osobny rozdział poświęcono debugowaniu aplikacji wielowątkowych. Książka ta jest długo oczekiwaną pozycją, która ułatwi codzienne życie programistom C++.

Dzięki tej książce:

  • zaprojektujesz współbieżny kod oraz struktury
  • ochronisz współdzielone dane
  • poznasz zaawansowane metody zarzÄ…dzania wÄ…tkami
  • bez problemu przeprowadzisz debugowanie Twojej wielowÄ…tkowej aplikacji

Sprawdź, jak tworzyć niezawodne oprogramowanie wielowątkowe!

Dodaj do koszyka Język C++ i przetwarzanie współbieżne w akcji

Dodaj do koszyka Język C++ i przetwarzanie współbieżne w akcji

Spis treści

Język C++ i przetwarzanie współbieżne w akcji eBook -- spis treści

Słowo wstępne (11)

Podziękowania (13)

O tej książce (15)

Rozdział 1. Witaj, świecie współbieżności w C++! (19)

  • 1.1. Czym jest współbieżność? (20)
    • 1.1.1. Współbieżność w systemach komputerowych (20)
    • 1.1.2. Modele współbieżnoÅ›ci (22)
  • 1.2. Dlaczego warto stosować współbieżność? (25)
    • 1.2.1. Stosowanie współbieżnoÅ›ci do podziaÅ‚u zagadnieÅ„ (25)
    • 1.2.2. Stosowanie współbieżnoÅ›ci do podniesienia wydajnoÅ›ci (26)
    • 1.2.3. Kiedy nie należy stosować współbieżnoÅ›ci (27)
  • 1.3. Współbieżność i wielowÄ…tkowość w jÄ™zyku C++ (28)
    • 1.3.1. Historia przetwarzania wielowÄ…tkowego w jÄ™zyku C++ (29)
    • 1.3.2. ObsÅ‚uga współbieżnoÅ›ci w nowym standardzie (30)
    • 1.3.3. Efektywność biblioteki wÄ…tków jÄ™zyka C++ (30)
    • 1.3.4. Mechanizmy zwiÄ…zane z poszczególnymi platformami (32)
  • 1.4. Do dzieÅ‚a! (32)
    • 1.4.1. "Witaj Å›wiecie współbieżnoÅ›ci" (32)
  • 1.5. Podsumowanie (34)

Rozdział 2. Zarządzanie wątkami (35)

  • 2.1. Podstawowe zarzÄ…dzanie wÄ…tkami (36)
    • 2.1.1 Uruchamianie wÄ…tku (36)
    • 2.1.2. Oczekiwanie na zakoÅ„czenie wÄ…tku (39)
    • 2.1.3. Oczekiwanie w razie wystÄ…pienia wyjÄ…tku (39)
    • 2.1.4. Uruchamianie wÄ…tków w tle (42)
  • 2.2. Przekazywanie argumentów do funkcji wÄ…tku (43)
  • 2.3. Przenoszenie wÅ‚asnoÅ›ci wÄ…tku (46)
  • 2.4. Wybór liczby wÄ…tków w czasie wykonywania (49)
  • 2.5. Identyfikowanie wÄ…tków (52)
  • 2.6. Podsumowanie (54)

Rozdział 3. Współdzielenie danych przez wątki (55)

  • 3.1. Problemy zwiÄ…zane ze współdzieleniem danych przez wÄ…tki (56)
    • 3.1.1. Sytuacja wyÅ›cigu (58)
    • 3.1.2. Unikanie problematycznych sytuacji wyÅ›cigu (59)
  • 3.2. Ochrona współdzielonych danych za pomocÄ… muteksów (60)
    • 3.2.1. Stosowanie muteksów w jÄ™zyku C++ (60)
    • 3.2.2. Projektowanie struktury kodu z myÅ›lÄ… o ochronie współdzielonych danych (62)
    • 3.2.3. Wykrywanie sytuacji wyÅ›cigu zwiÄ…zanych z interfejsami (63)
    • 3.2.4. Zakleszczenie: problem i rozwiÄ…zanie (71)
    • 3.2.5. Dodatkowe wskazówki dotyczÄ…ce unikania zakleszczeÅ„ (73)
    • 3.2.6. Elastyczne blokowanie muteksów za pomocÄ… szablonu std::unique_lock (79)
    • 3.2.7. Przenoszenie wÅ‚asnoÅ›ci muteksu pomiÄ™dzy zasiÄ™gami (80)
    • 3.2.8. Dobór wÅ‚aÅ›ciwej szczegółowoÅ›ci blokad (82)
  • 3.3. Alternatywne mechanizmy ochrony współdzielonych danych (84)
    • 3.3.1. Ochrona współdzielonych danych podczas inicjalizacji (84)
    • 3.3.2. Ochrona rzadko aktualizowanych struktur danych (88)
    • 3.3.3. Blokowanie rekurencyjne (90)
  • 3.4. Podsumowanie (91)

Rozdział 4. Synchronizacja współbieżnych operacji (93)

  • 4.1. Oczekiwanie na zdarzenie lub inny warunek (94)
    • 4.1.1. Oczekiwanie na speÅ‚nienie warunku za pomocÄ… zmiennych warunkowych (95)
    • 4.1.2. Budowa kolejki gwarantujÄ…cej bezpieczne przetwarzanie wielowÄ…tkowe przy użyciu zmiennych warunkowych (97)
  • 4.2. Oczekiwanie na jednorazowe zdarzenia za pomocÄ… przyszÅ‚oÅ›ci (102)
    • 4.2.1. Zwracanie wartoÅ›ci przez zadania wykonywane w tle (103)
    • 4.2.2. WiÄ…zanie zadania z przyszÅ‚oÅ›ciÄ… (106)
    • 4.2.3. Obietnice (szablon std::promise) (109)
    • 4.2.4. Zapisywanie wyjÄ…tku na potrzeby przyszÅ‚oÅ›ci (111)
    • 4.2.5. Oczekiwanie na wiele wÄ…tków (112)
  • 4.3. Oczekiwanie z limitem czasowym (115)
    • 4.3.1. Zegary (115)
    • 4.3.2. Okresy (117)
    • 4.3.3. Punkty w czasie (118)
    • 4.3.4. Funkcje otrzymujÄ…ce limity czasowe (120)
  • 4.4. Upraszczanie kodu za pomocÄ… technik synchronizowania operacji (121)
    • 4.4.1. Programowanie funkcyjne przy użyciu przyszÅ‚oÅ›ci (122)
    • 4.4.2. Synchronizacja operacji za pomocÄ… przesyÅ‚ania komunikatów (127)
  • 4.5. Podsumowanie (131)

Rozdział 5. Model pamięci języka C++ i operacje na typach atomowych (133)

  • 5.1. Podstawowe elementy modelu pamiÄ™ci (134)
    • 5.1.1. Obiekty i miejsca w pamiÄ™ci (134)
    • 5.1.2. Obiekty, miejsca w pamiÄ™ci i przetwarzanie współbieżne (135)
    • 5.1.3. Kolejność modyfikacji (136)
  • 5.2. Operacje i typy atomowe jÄ™zyka C++ (137)
    • 5.2.1. Standardowe typy atomowe (138)
    • 5.2.2. Operacje na typie std::atomic_flag (141)
    • 5.2.3. Operacje na typie std::atomic<bool> (143)
    • 5.2.4. Operacje na typie std::atomic<T*> - arytmetyka wskaźników (146)
    • 5.2.5. Operacje na standardowych atomowych typach caÅ‚kowitoliczbowych (147)
    • 5.2.6. Główny szablon klasy std::atomic<> (147)
    • 5.2.7. Wolne funkcje dla operacji atomowych (150)
  • 5.3. Synchronizacja operacji i wymuszanie ich porzÄ…dku (151)
    • 5.3.1. Relacja synchronizacji (152)
    • 5.3.2. Relacja poprzedzania (154)
    • 5.3.3. PorzÄ…dkowanie pamiÄ™ci na potrzeby operacji atomowych (155)
    • 5.3.4. Sekwencje zwalniania i relacja synchronizacji (175)
    • 5.3.5. Ogrodzenia (178)
    • 5.3.6. PorzÄ…dkowanie operacji nieatomowych za pomocÄ… operacji atomowych (180)
  • 5.4. Podsumowanie (182)

Rozdział 6. Projektowanie współbieżnych struktur danych przy użyciu blokad (183)

  • 6.1. Co oznacza projektowanie struktur danych pod kÄ…tem współbieżnoÅ›ci? (184)
    • 6.1.1. Wskazówki dotyczÄ…ce projektowania współbieżnych struktur danych (185)
  • 6.2. Projektowanie współbieżnych struktur danych przy użyciu blokad (186)
    • 6.2.1. Stos gwarantujÄ…cy bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego przy użyciu blokad (187)
    • 6.2.2. Kolejka gwarantujÄ…ca bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego przy użyciu blokad i zmiennych warunkowych (190)
    • 6.2.3. Kolejka gwarantujÄ…ca bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego przy użyciu szczegółowych blokad i zmiennych warunkowych (194)
  • 6.3. Projektowanie zÅ‚ożonych struktur danych przy użyciu blokad (207)
    • 6.3.1. Implementacja tablicy wyszukiwania gwarantujÄ…cej bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego przy użyciu blokad (207)
    • 6.3.2. Implementacja listy gwarantujÄ…cej bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego przy użyciu blokad (213)
  • 6.4. Podsumowanie (218)

Rozdział 7. Projektowanie współbieżnych struktur danych bez blokad (219)

  • 7.1. Definicje i ich praktyczne znaczenie (220)
    • 7.1.1. Rodzaje nieblokujÄ…cych struktur danych (220)
    • 7.1.2. Struktury danych bez blokad (221)
    • 7.1.3. Struktury danych bez oczekiwania (222)
    • 7.1.4. Zalety i wady struktur danych bez blokad (222)
  • 7.2. PrzykÅ‚ady struktur danych bez blokad (223)
    • 7.2.1. Implementacja stosu gwarantujÄ…cego bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego bez blokad (224)
    • 7.2.2. Eliminowanie niebezpiecznych wycieków - zarzÄ…dzanie pamiÄ™ciÄ… w strukturach danych bez blokad (228)
    • 7.2.3. Wykrywanie wÄ™złów, których nie można odzyskać, za pomocÄ… wskaźników ryzyka (233)
    • 7.2.4. Wykrywanie używanych wÄ™złów metodÄ… zliczania referencji (242)
    • 7.2.5. Zmiana modelu pamiÄ™ci używanego przez operacje na stosie bez blokad (247)
    • 7.2.6. Implementacja kolejki gwarantujÄ…cej bezpieczeÅ„stwo przetwarzania wielowÄ…tkowego bez blokad (252)
  • 7.3. Wskazówki dotyczÄ…ce pisania struktur danych bez blokad (264)
    • 7.3.1. Wskazówka: na etapie tworzenia prototypu należy stosować tryb std::memory_order_seq_cst (265)
    • 7.3.2. Wskazówka: należy używać schematu odzyskiwania pamiÄ™ci bez blokad (265)
    • 7.3.3 Wskazówka: należy unikać problemu ABA (266)
    • 7.3.4. Wskazówka: należy identyfikować pÄ™tle aktywnego oczekiwania i wykorzystywać czas bezczynnoÅ›ci na wspieranie innego wÄ…tku (267)
  • 7.4. Podsumowanie (267)

Rozdział 8. Projektowanie współbieżnego kodu (269)

  • 8.1. Techniki dzielenia pracy pomiÄ™dzy wÄ…tki (270)
    • 8.1.1. Dzielenie danych pomiÄ™dzy wÄ…tki przed rozpoczÄ™ciem przetwarzania (271)
    • 8.1.2. Rekurencyjne dzielenie danych (272)
    • 8.1.3. Dzielenie pracy wedÅ‚ug typu zadania (276)
  • 8.2. Czynniki wpÅ‚ywajÄ…ce na wydajność współbieżnego kodu (279)
    • 8.2.1. Liczba procesorów (280)
    • 8.2.2. Współzawodnictwo o dane i ping-pong bufora (281)
    • 8.2.3. FaÅ‚szywe współdzielenie (284)
    • 8.2.4. Jak blisko należy rozmieÅ›cić dane? (285)
    • 8.2.5. Nadsubskrypcja i zbyt intensywne przeÅ‚Ä…czanie zadaÅ„ (285)
  • 8.3. Projektowanie struktur danych pod kÄ…tem wydajnoÅ›ci przetwarzania wielowÄ…tkowego (286)
    • 8.3.1. PodziaÅ‚ elementów tablicy na potrzeby zÅ‚ożonych operacji (287)
    • 8.3.2. Wzorce dostÄ™pu do danych w pozostaÅ‚ych strukturach (289)
  • 8.4. Dodatkowe aspekty projektowania współbieżnych struktur danych (291)
    • 8.4.1. BezpieczeÅ„stwo wyjÄ…tków w algorytmach równolegÅ‚ych (291)
    • 8.4.2. Skalowalność i prawo Amdahla (298)
    • 8.4.3. Ukrywanie opóźnieÅ„ za pomocÄ… wielu wÄ…tków (300)
    • 8.4.4. Skracanie czasu reakcji za pomocÄ… technik przetwarzania równolegÅ‚ego (301)
  • 8.5. Projektowanie współbieżnego kodu w praktyce (303)
    • 8.5.1. RównolegÅ‚a implementacja funkcji std::for_each (304)
    • 8.5.2. RównolegÅ‚a implementacja funkcji std::find (306)
    • 8.5.3. RównolegÅ‚a implementacja funkcji std::partial_sum (312)
  • 8.6. Podsumowanie (322)

Rozdział 9. Zaawansowane zarządzanie wątkami (323)

  • 9.1. Pule wÄ…tków (324)
    • 9.1.1. Najprostsza możliwa pula wÄ…tków (324)
    • 9.1.2. Oczekiwanie na zadania wysyÅ‚ane do puli wÄ…tków (327)
    • 9.1.3. Zadania oczekujÄ…ce na inne zadania (330)
    • 9.1.4. Unikanie współzawodnictwa w dostÄ™pie do kolejki zadaÅ„ (333)
    • 9.1.5. Wykradanie zadaÅ„ (335)
  • 9.2. Przerywanie wykonywania wÄ…tków (340)
    • 9.2.1. Uruchamianie i przerywanie innego wÄ…tku (340)
    • 9.2.2. Wykrywanie przerwania wÄ…tku (342)
    • 9.2.3. Przerywanie oczekiwania na zmiennÄ… warunkowÄ… (343)
    • 9.2.4. Przerywanie oczekiwania na zmiennÄ… typu std::condition_variable_any (346)
    • 9.2.5. Przerywanie pozostaÅ‚ych wywoÅ‚aÅ„ blokujÄ…cych (348)
    • 9.2.6. ObsÅ‚uga przerwaÅ„ (349)
    • 9.2.7. Przerywanie zadaÅ„ wykonywanych w tle podczas zamykania aplikacji (350)
  • 9.3. Podsumowanie (352)

Rozdział 10. Testowanie i debugowanie aplikacji wielowątkowych (353)

  • 10.1. Rodzaje bÅ‚Ä™dów zwiÄ…zanych z przetwarzaniem współbieżnym (354)
    • 10.1.1. Niechciane blokowanie (354)
    • 10.1.2. Sytuacje wyÅ›cigu (355)
  • 10.2. Techniki lokalizacji bÅ‚Ä™dów zwiÄ…zanych z przetwarzaniem współbieżnym (357)
    • 10.2.1. PrzeglÄ…danie kodu w celu znalezienia ewentualnych bÅ‚Ä™dów (357)
    • 10.2.2. Znajdowanie bÅ‚Ä™dów zwiÄ…zanych z przetwarzaniem współbieżnym poprzez testowanie kodu (359)
    • 10.2.3. Projektowanie kodu pod kÄ…tem Å‚atwoÅ›ci testowania (361)
    • 10.2.4. Techniki testowania wielowÄ…tkowego kodu (363)
    • 10.2.5. Projektowanie struktury wielowÄ…tkowego kodu testowego (366)
    • 10.2.6. Testowanie wydajnoÅ›ci wielowÄ…tkowego kodu (369)
  • 10.3. Podsumowanie (370)

Dodatek A Krótki przegląd wybranych elementów języka C++11 (371)

  • A.1. Referencje do r-wartoÅ›ci (371)
    • A.1.1. Semantyka przenoszenia danych (372)
    • A.1.2. Referencje do r-wartoÅ›ci i szablony funkcji (375)
  • A.2. UsuniÄ™te funkcje (376)
  • A.3. Funkcje domyÅ›lne (377)
  • A.4. Funkcje constexpr (381)
    • A.4.1. Wyrażenia constexpr i typy definiowane przez użytkownika (382)
    • A.4.2. Obiekty constexpr (385)
    • A.4.3. Wymagania dotyczÄ…ce funkcji constexpr (385)
    • A.4.4. SÅ‚owo constexpr i szablony (386)
  • A.5. Funkcje lambda (386)
    • A.5.1. Funkcje lambda odwoÅ‚ujÄ…ce siÄ™ do zmiennych lokalnych (388)
  • A.6. Szablony zmiennoargumentowe (391)
    • A.6.1. Rozwijanie paczki parametrów (392)
  • A.7. Automatyczne okreÅ›lanie typu zmiennej (395)
  • A.8. Zmienne lokalne wÄ…tków (396)
  • A.9. Podsumowanie (397)

Dodatek B Krótkie zestawienie bibliotek przetwarzania współbieżnego (399)

Dodatek C Framework przekazywania komunikatów i kompletny przykład implementacji systemu bankomatu (401)

Dodatek D Biblioteka wątków języka C++ (419)

  • D.1. Nagłówek <chrono> (419)
    • D.1.1. Szablon klasy std::chrono::duration (420)
    • D.1.2. Szablon klasy std::chrono::time_point (429)
    • D.1.3. Klasa std::chrono::system_clock (431)
    • D.1.4. Klasa std::chrono::steady_clock (433)
    • D.1.5. Definicja typu std::chrono::high_resolution_clock (435)
  • D.2. Nagłówek <condition_variable> (435)
    • D.2.1. Klasa std::condition_variable (436)
    • D.2.2. Klasa std::condition_variable_any (444)
  • D.3. Nagłówek <atomic> (452)
    • D.3.1. Definicje typów std::atomic_xxx (454)
    • D.3.2. Makra ATOMIC_xxx_LOCK_FREE (454)
    • D.3.3. Makro ATOMIC_VAR_INIT (455)
    • D.3.4. Typ wyliczeniowy std::memory_order (455)
    • D.3.5. Funkcja std::atomic_thread_fence (456)
    • D.3.6. Funkcja std::atomic_signal_fence (457)
    • D.3.7. Klasa std::atomic_flag (457)
    • D.3.8. Szablon klasy std::atomic (460)
    • D.3.9. Specjalizacje szablonu std::atomic (471)
    • D.3.10. Specjalizacje szablonu std::atomic<typ-caÅ‚kowitoliczbowy> (472)
  • D.4. Nagłówek <future> (489)
    • D.4.1. Szablon klasy std::future (490)
    • D.4.2. Szablon klasy std::shared_future (495)
    • D.4.3. Szablon klasy std::packaged_task (501)
    • D.4.4. Szablon klasy std::promise (507)
    • D.4.5. Szablon funkcji std::async (513)
  • D.5. Nagłówek <mutex> (514)
    • D.5.1. Klasa std::mutex (515)
    • D.5.2. Klasa std::recursive_mutex (518)
    • D.5.3. Klasa std::timed_mutex (520)
    • D.5.4. Klasa std::recursive_timed_mutex (524)
    • D.5.5. Szablon klasy std::lock_guard (529)
    • D.5.6. Szablon klasy std::unique_lock (530)
    • D.5.7. Szablon funkcji std::lock (540)
    • D.5.8. Szablon funkcji std::try_lock (541)
    • D.5.9. Klasa std::once_flag (541)
    • D.5.10. Szablon funkcji std::call_once (542)
  • D.6. Nagłówek <ratio> (543)
    • D.6.1. Szablon klasy std::ratio (544)
    • D.6.2. Alias szablonu std::ratio_add (544)
    • D.6.3. Alias szablonu std::ratio_subtract (545)
    • D.6.4. Alias szablonu std::ratio_multiply (545)
    • D.6.5. Alias szablonu std::ratio_divide (546)
    • D.6.6. Szablon klasy std::ratio_equal (547)
    • D.6.7. Szablon klasy std::ratio_not_equal (547)
    • D.6.8. Szablon klasy std::ratio_less (547)
    • D.6.9. Szablon klasy std::ratio_greater (548)
    • D.6.10. Szablon klasy std::ratio_less_equal (548)
    • D.6.11. Szablon klasy std::ratio_greater_equal (548)
  • D.7. Nagłówek <thread> (549)
    • D.7.1. Klasa std::thread (549)
    • D.7.2. PrzestrzeÅ„ nazw std::this_thread (558)

Materiały dodatkowe (561)

Skorowidz (563)

Dodaj do koszyka Język C++ i przetwarzanie współbieżne w akcji

Code, Publish & WebDesing by CATALIST.com.pl



(c) 2005-2024 CATALIST agencja interaktywna, znaki firmowe należą do wydawnictwa Helion S.A.