такой пример параллелизма (код: 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
да, быстро отрабатывает. на сайте такой же вывод можно увидеть
там смысл кажется не в быстроте, а в том что логика в preimptive поменялась с какой то версии
можешь подробнее?
вот сначала они решили проблему бесконечных циклов https://developpaper.com/goroutine-preemptive-scheduling-with-new-features-of-go-1-14/
Обсуждают сегодня