-
Data: 2014-05-24 15:41:38
Temat: Re: Wielowątkowość - podstawowe pytanie
Od: Andrzej Jarzabek <a...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 24/05/2014 12:29, Piotrek wrote:
> Wyjaśnijcie mi taką jedną rzecz. Niby mam ogólne,
> teoretyczne pojęcie o wielowątkowości - wiem z czym
> to się je, jakie problemy wiążą się z programowaniem
> wielowątkowym, ale zawsze zastanawiała mnie taka jedna
> fundamentalna kwestia: dlaczego programiści w ogóle muszą
> być świadomi tego, że programują wielowątkowo, tzn. dlaczego
> samodzielnie muszą używać muteksów i innych mechanizmów
> synchronizacji wątków? Może bredzę, ale nie dałoby się tego
> jakoś rozwiązać na poziomie samego języka? Dlaczego każda
> instrukcja programu nie jest domyślnie atomowa, tzn. kompilator
> przy generowaniu kodu sam nie emuluje atomowości
> wstawiając gdzie trzeba różne locki/unlocki tak, żeby
> w ogóle nie trzeba było o tym myśleć? Chodzi o to, że
> byłoby to niewydajne?
W Erlangu, Haskellu czy Go możesz spokojnie pisać programy wykonujące
się na wielu wątkach bez żadnego grzebania w lockach.
Jeśli chodzi konkretnie o programowanie imperatywne z dzieleniem stanu,
to również istnieją biblioteki pozwalające na ominięcie problemu jawnego
używania locków, ale oczywiście samo użycie nie gwarantuje braku data
races w programie. To, co proponujesz rzeczywiście byłoby niewydajne -
nawet tam, gdzie architektura gwarantuje atomowość pewnych operacji (np.
zapisu lub odczytu słowa maszynowego) optymalizacje procesora powodują
że poszczególne atomowe operacje mogą być widoczne w różnej kolejności z
różnych wątków. O większych operacjach, gdzie kompilator musiałby
zakładać locka za każdym razem, kiedy instrukcja języka przekłada się na
więcej niż jedną instrukcję procesora już lepiej nie mówić. Przede
wszystkim jednak nie rozwiązuje to problemu: kompilator nadal nie wie,
co jest atomową instrukcją z punktu widzenia semantyki twojego programu.
Wyobraź sobie np. że masz taką strukturę jak lista dwukierunkowa.
Operacje jak wstawienie czy usunięcie elementu wymagają kilku operacji
odczytania i zapisania wskaźników. Nawet jeśli każda z tym operacji na
wskaźnikach jest atomowa, a nawet jeśli kompilator zadbał żeby np.
skopiowanie wartości wskaźnika było atomową operacją, to nadal (jeśli
nie zaznaczysz tego jakoś w programie) kompilator nie ma podstaw żeby
uważać, że tych kilka kopiowań wskaźników jest również operacją atomową
- to ty wiesz, że implementujesz listę dwukierunkową, kompilator tego
nie wie. I oczywiście jeśli same kopiowania są atomowe, ale całe
wstawienie/usunięcie elementu nie jest, to masz data race: co by się
działo jakby w połowie wstawiania elementu do listy przez jeden wątek
drugi postanowił wykonać inną operację - np. usunąć poprzedzający
element? Oczywiście tak w ogóle da się zdefiniować listę z zaznaczeniem
co jest atomową operacją bez jawnego używania locków - poczytaj sobie
np. o monitorach.
Następne wpisy z tego wątku
- 24.05.14 19:20 Stachu 'Dozzie' K.
- 24.05.14 20:43 A.L.
- 25.05.14 01:34 firr
- 25.05.14 03:10 firr
- 25.05.14 07:00 slawek
- 25.05.14 08:39 Edek
- 27.05.14 10:52 Adam Wysocki
- 04.06.14 19:59 Piotrek
- 04.06.14 20:02 Edek
- 04.06.14 21:10 Piotrek
- 04.06.14 22:19 Edek
Najnowsze wątki z tej grupy
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
Najnowsze wątki
- 2024-12-30 Sędzia Dorota Lenarczyk z Żywca skazała na 6 mies. pozbawienia wolności
- 2024-12-30 Podnieść masę o 0.6V
- 2024-12-30 Białystok => Full Stack .Net Engineer <=
- 2024-12-30 Białystok => Analityk w dziale Trade Development (doświadczenie z Po
- 2024-12-30 Gdańsk => Software .Net Developer <=
- 2024-12-30 Białystok => Full Stack web developer (obszar .Net Core, Angular6+) <
- 2024-12-30 Białystok => Programista Full Stack (.Net Core) <=
- 2024-12-30 Moduł BT BLE 5.0
- 2024-12-30 Łódź => Application Security Engineer <=
- 2024-12-30 Lublin => Inżynier bezpieczeństwa aplikacji <=
- 2024-12-30 Nowy Outlander PHEV w PL
- 2024-12-30 Warszawa => Key Account Manager <=
- 2024-12-30 Katowice => Key Account Manager (ERP) <=
- 2024-12-28 Śmiechu KOOOOOOPA ;-)
- 2024-12-29 Pomiar amplitudy w zegarku mechanicznym