170 похожих чатов

Всем привет. Читал сейчас статью про горутины и там приводится

такой пример параллелизма (код: https://go.dev/play/p/Tkhp8-UL3Zk), а выводит этот пример данные в произвольном порядке из двух горутин:


a b 1 2 3 4 c d e f 5 g h 6 i 7 j 8 k 9 10 11 12 l m n o p q 13 r s 14 t 15 u v 16 w 17 x y 18 z 19 20 21 22 23 24 25 26

и мне понятно, что происходит это из-за одновременного выполнения этих двух горутин. Но когда я запускаю у себя на компе, то получаю результат:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 a b c d e f g h i j k l m n o p q r s t u v w x y z

и вот тут уже не понятно, почему горутины выполняются последовательно? Потому что на моем компе 2-я горутина слишком быстро отрабатывает, а 1-я еще не успела запуститься?

На компе runtime.NumCPU() == 4

4 ответов

11 просмотров

да, быстро отрабатывает. на сайте такой же вывод можно увидеть

Illia 🇺🇦
да, быстро отрабатывает. на сайте такой же вывод м...

там смысл кажется не в быстроте, а в том что логика в preimptive поменялась с какой то версии

вот сначала они решили проблему бесконечных циклов https://developpaper.com/goroutine-preemptive-scheduling-with-new-features-of-go-1-14/

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта