eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingWielowątkowość - podstawowe pytanieRe: Wielowątkowość - podstawowe pytanie
  • Data: 2014-05-24 19:20:16
    Temat: Re: Wielowątkowość - podstawowe pytanie
    Od: "Stachu 'Dozzie' K." <d...@g...eat.some.screws.spammer.invalid> szukaj wiadomości tego autora
    [ pokaż wszystkie nagłówki ]

    On 2014-05-24, Piotrek <p...@p...onet.pl> 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?

    Nie. Chodzi o to, że nie wystarczy aby *instrukcja* ma być atomowa. Cała
    *sekwencja* instrukcji ma być niepodzielna.

    Ale pamięć współdzielona to nie jest jedyny model obliczeń
    współbieżnych. Jest też model przesyłania komunikatów -- wtedy masz
    mnóstwo obliczeń jednowątkowych, które tylko wymieniają się ze sobą
    danymi i nie ma problemu z jednoczesnym dostępem do zasobów.

    --
    Secunia non olet.
    Stanislaw Klekot

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: