Dlaczego wątki nazywane są wątkami?


9

Rozumiem, że proces to jednostka własności zasobów i instrukcje wykonywalne. Wątki pozwalają procesowi współużytkować zasoby z wieloma wykonaniami, a systemowi operacyjnemu łatwiej jest zaplanować wątki z powodu całego obciążenia związanego z całymi procesami.

Ale dlaczego nazwa wątku ? Czy ma jakieś odniesienie do łańcucha lub przeplatania wykonania? Mimo to moim zdaniem nie jest to termin intuicyjny.

Odpowiedzi:


11

Czy szukałeś w słowniku? Słowo „ wątek” ma znaczenie przeszłego szycia.

3: coś ciągłego lub wyciągniętego: jak

Odp .: linia rozumowania lub tok myśli łączący części w sekwencji (według pomysłów lub wydarzeń)

http://www.merriam-webster.com/dictionary/thread


Ciekawy. Przeprowadziłem wyszukiwanie „zdefiniuj wątek”, ale ta definicja nie była jedną z nich. Cieszę się, że o tym wspomniałeś, ponieważ jest wystarczająco abstrakcyjny, aby przejść przez most od ogólnego zastosowania do programowania.
Matt

9

Widziałeś kiedyś, jak wiele nici, skręconych, tworzy grubszy, mocniejszy sznur?

To jest metafora, każdy wątek jest niezależny, ale wszystkie wątki razem współpracują w celu uzyskania ostatecznego wyniku obliczeniowego. Poza tym, podobnie jak w przypadku nici tekstylnej, nić może pęknąć bez naruszenia struktury całego kordu.

wprowadź opis zdjęcia tutaj


2
podczas gdy zawsze wyobrażałem sobie „wątki”, tylko ty i GrandmasterB opisywaliście je, nie jestem pewien co do całego „skręconego, grubszego, mocniejszego sznurka”. Zamiast tego większość wątków w systemie operacyjnym wygląda mniej więcej tak: miqel.com/bonnaroo_2008_music/yarn_string_trips.jpg (facet po prawej stronie to kontroler pamięci) Tak, czasami kilka z tych ciągów ma rozwiązać typowy problem, ale większość właśnie tam, a system operacyjny pozwala im wszystkim robić, co chcą (w granicach rozsądku)
DXM

7

tl; dr: Nazywa się je wątkami, ponieważ „wątek” jest trafną metaforą.


Kiedy uruchamiasz wątek, polegasz na systemie operacyjnym, aby przydzielić czas przetwarzania, aby twój wątek mógł wykonać. Podczas wykonywania wątku procesor (lub rdzeń) kładzie całą uwagę na wątek. Gdy system operacyjny przełącza rdzeń na inny wątek, wątek przestaje działać, gdy drugi wątek jest obsługiwany.

A więc egzekucja przeskakuje wszędzie. Ale pomimo tych skoków integralność zestawu instrukcji maszynowych pozostaje nienaruszona, ponieważ budujemy ogrodzenia i mechanizmy współbieżności, aby chronić jego stan oraz stan obiektów, z którymi wchodzi on w interakcje.

Tak więc wątek odnosi się nie do wykonywania instrukcji w danym wątku, ale do instrukcji, które ostatecznie zostaną wykonane w wątku, który utworzyliśmy. Innymi słowy, każdy wątek można traktować jako pojedynczą maszynę lub agenta (nazywamy je lekkimi procesami), bez konieczności myślenia o wszystkich przełącznikach kontekstu, które wykonuje system operacyjny, aby wyglądać, jakby wszystkie były wykonywanie jednocześnie.

Innymi słowy, pomimo całego przeskakiwania, które system operacyjny wykonuje za kulisami, to, co nazywamy wątkiem (sekwencja operacji, które wykonujemy w lekkim procesie), nadal można uznać za tę samą sekwencję operacji, gdybyśmy nie spawnowali wątku, zakładając, że podjęliśmy niezbędną ochronę przed współbieżnością.


Jeśli ten opis wydaje się zbyt ciężki i abstrakcyjny, pomyśl o wątku na forum, takim jak Reddit. Możesz rozgałęziać nowe dyskusje; każda dyskusja ma swój własny wątek. Możesz przeskakiwać między wątkami. Ale każdy wątek nadal zachowuje integralność strukturalną jako indywidualna rozmowa.


4

Trudno jest rozplątać (w pełni zamierzony kalambur) źródło terminu „Wątek”, ponieważ różne rzeczy mętnieją w wodzie.

Użycie wątku na forum lub w poczcie e-mailowej prawie na pewno wynika z wyrażenia „wątek rozmowy”, które zgodnie z tym datuje się na 1593 rok.

Wydaje się, że znaczenie wątku, o który pytasz, jest mniej jasne, ponieważ zgodnie z tym linkiem wątki, które znamy, nie były tak naprawdę nazywane „wątkami” aż do lat 70. lub prawdopodobnie wczesnych lat 80., pomimo wdrożenia procesu pamięci dzielonej faktycznie wyprzedzając to, co dziś nazywamy procesami wagi ciężkiej. Biorąc pod uwagę, że pokrewna forma wieloprocesowego przetwarzania pamięci wspólnej nazywana jest „włóknem”, podejrzewam, że słowo „nić” powinno przypominać tkaninę tkacką lub inną analogię związaną z tkaniną.


3

Myślę, że ma to związek z „wątkiem rozumowania” lub „wątkiem myśli”.

W przeciwieństwie do procesu wątki współużytkują pamięć. Więc jeśli proces jest porównywany do osoby z własnym umysłem (pamięcią), nitkę można porównać do jednej linii myśli w tym umyśle.


1

Czytałem gdzieś analogię wątków w programowaniu: myślę, że procesor to igła do szycia, a nić jako faktyczny ciąg. Teraz, jeśli masz wiele igieł do szycia, ale tylko jedną nić. Nie sądzisz, że będzie to dość nieefektywne. Druga procesor / igła do szycia będzie czekać na dostępność nici. Jeśli jednak mamy wiele wątków, zadanie można wykonać w krótkim czasie.


1
co jest z tym nie tak? Dlaczego -1?
zręczny
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.