Антон Сергеев, «Go под капотом»
Kolesa Go Meetup:
Доклад о том, как работает go изнутри, и чем его принципы отличаются от других популярных языков. Что нужно знать о работе компилятора, операционной системы и компьютера, чтобы пользоваться go эффективно. Также рассмотрим, как устроены горутины, и почему в языке есть несколько способов сделать одно и то же, когда речь идет о конкурентности.
Полезные ссылки:
habr.com/ru/company/mailru/bl...
rakyll.org/codegen/ • GopherCon 2018: Kavya ... morsmachine.dk/go-scheduler
www.ardanlabs.com/blog/2018/0...
blog.cloudflare.com/how-stack...
dave.cheney.net
Пікірлер: 85
С первых слов понятно, что лекция будет огненная! Спасибо большое за доклад!
Спасибо! С нетерпением ждем новых докладов Антона!)
Спасибо большое за интересный доклад!
Очень интересно. Спасибо
Толковый доклад, спасибо большое !
Отличный доклад!
Интересный доклад, респект автору!
Доклад огонь, докладчику респект!
Спасибо за видео. Коммент в поддержку!
Хороший доклад, интересно послушать о кишках го)
Отличный доклад, спасибо. Было бы интересно послушать и про аллокации памяти с garbage collector )
Good explanation! I see you dived much profoundly. Thanks for your speach.
просто огонь=)) очень понятно про и простыми словами про го=))
Про работу каналов Go, в таком глубоком формате, - было бы тоже интересно послушать ;) Спасибо!
@alexander.emelin
3 жыл бұрын
kzread.info/dash/bejne/hqRp2sqNfanbfLg.html - про каналы, плюс на медиуме отличная статья medium.com/a-journey-with-go/go-buffered-and-unbuffered-channels-29a107c00268
@realmoftheminone
2 жыл бұрын
О ты же чел из Fiber
@mini_clop
Жыл бұрын
@@alexander.emelin От души, душево в душе!
сразу лайк за зелёные треды, мало кто про них вспоминает
отличный доклад, надеюсь на текущий момент рантайм не сильно поменялся)))
Очень переживал за паутинку
9:44 issue по внедрению вытесняющей многозадачности закрыт. Подскажите, вытесняющую многозадачность внедрили?
Спасибо за доклад, очень интересно и доступным языком! Подскажите где можно посмотреть про работу: каналов, мьютексов и взаимодействие с контекстом ?
@alexanderloginov2762
Жыл бұрын
D. Curry Unix system programming. W. Stevens Unix IPC E. Raymond The Art of UNIX programming Если ничего не напутал с названиями.
Очень хотел использовать GO в звездолёте, но облом по времени выполнения. Ладно, буду на ассемблере и Сишке пилить 😎
@user-rj5kt3ft8w
Жыл бұрын
напилил?
Почему он похож на маскота GO? 😅
@user-ub7qu4yo2i
2 ай бұрын
Он стал превращаться в GO
Ни фига себе, у этого видео 60К просмотров 👍🏻
8:28 - побуду немного душным. В коммунизме идеал распределения описывается фразой: "От каждого по способностям, каждому по потребностям". То есть, больше схоже с тем, что спикер записал в "Кооперативную" модель. Я не спец по измам, но этот момент помню))
с версии 1.14 уже некооперативный, то есть preemptible
сейчас уже только вытесняющая и никакой кооперативности уже не осталось в новой версии
Здравствуйте, спасибо за доклад! У меня остался вопрос. Допустим я пишу парсер. Есть 1ярд подготовленных урлов. Как лучше организовать рабочий цикл. Запустить скажем 1000 горутин (которые будут складывать результат в бд) и потом скармливать им через канал новые урлы в цикле. Или сразу в основном цикле на каждый урл создавать горутину?
@antonsergeyev
Жыл бұрын
Привет! Первый способ точно лучше. Такой подход называется worker pool, он позволяет предсказуемо контролировать потребление ресурсов. Простой пример приведён здесь gobyexample.com/worker-pools, есть и более усложнённые варианты. А пытаться создать 1 миллиард горутин я не пробовал, но рискну предположить, что не получится :)
@arnowt
Жыл бұрын
@@antonsergeyev да, я уже протестировал оба варианта. Он действительно не создаёт ярд горутин. Создаёт какое-то кол-во тыс и потом по мере завершения одних создаёт другие и да, это сильно медленнее.
1:20 программы на go собранные gc ВСЕГДА статические, если вы не используете сишные вызовы с cgo Для hello world вовсе необязательно включать fmt, есть встроенная функция print()
@ilya_de
Жыл бұрын
print делает вывод в STDERR а не в STDOUT
Если в планировщике треда происходит Runtime.Goschedule и исполнение задачи выталкивается в другой тред, то как на это реагирует планировщик треда приемника ? Ему же придется тоже перебросить свои ранее запланированные подзадачи и т.д. в других тредах ?! Нужна ли эта суета или планировщик без Runtime.Goschedule нормально отработает ? Есть ли бенчмарк статистика, оправдывающая вмешательство разраба с ручным вызовом Runtime.Goschedule и говорящая, что от этого есть временной профит ?
@antonsergeyev
Жыл бұрын
Думаю, что в современных версиях языка функция Goschedule уже не очень актуальна - в язык уже добавили принудительное вытеснение горутин (на момент доклада его ещё не было). Так что я склоняюсь к тому, что суета не нужна :)
на Си легко реализуется код , аналогичный планировщику горутин, причём он заведомо будет более гибкий.
@dd-qz2rh
5 ай бұрын
Умение вибирать правильний инструмент для конкретной задачи ето один из основних скилом хорошего разраба. Не понимание для чего существуют разние уровни абстракции реализование при помощи разних ЯП ето призник слабого или же начинающего специалиста. На Си, как и на асемблере, можна написать абсолютно все. Ети же горутини и били на нем написани прежде чем переписани на го при уже работающем компиляторе го язика.
Я всякое слышал, от коллег в том числе, но Schedule как "скеджюал" мой новый абсолютный фаворит.
@user-lc8zz3hn7k
6 ай бұрын
Гугл Переводчик предлагает произность как "шеджюл"
@johndoe9604
5 ай бұрын
это правильное произношение
На каком уровне надо быть, что бы в это всё врубаться с первого раза?
@andreinorka2832
Жыл бұрын
Высшего образования хватит
@z3r0slab96
Жыл бұрын
А что не понятно?
@ngrx8750
Жыл бұрын
Кто в академ хорошо умеет, тот и врубается больше. Ну т.е. в базовые структуры и алгоритмы, там ЯП особо не при чём.
За printf() без trailing newline нужно казнить. Настолько сложно было " " добавить? bash-5.1$ echo "main(void) { printf(\"hello world\!\"); }" > main.c bash-5.1$ cc main.c 2>/dev/null && ./a.out hello world!bash-5.1$
23:58
А почему... неважно
Человек сильно разбирается в коммунизме)))
@maksimus.ssirotkin1124
4 ай бұрын
Идеал коммунизма как раз второе, правда его ни кто не видел.))
"Отнять и поделить" это лозунг совершенно других граждан.
@gregandark8571
3 жыл бұрын
🔯
@ottoreder9305
Жыл бұрын
@@gregandark8571 USSR :)
@gregandark8571
Жыл бұрын
@@ottoreder9305 ussr = ✡️
@achepkunov
Жыл бұрын
Ага, тоже не понравилось. При том, что не в тему, и в итоге все равно добавили. Потому, что,... ой, лучше тут остановлюсь)
.....извратили Forth😁
Я один слышу дрэды? 😅
Вот бы еще async/await в Golang вместо всех этих chan и go
@user-rj5kt3ft8w
9 ай бұрын
нет
Что за фигня верху записи плавает?
Это в РФ конфа? Просто смешной акцент у тех кто вопросы задавал)))
@AnelKerimbekova
2 жыл бұрын
это Алматы :))
Научите пацана правильно произносить англ. shedule. Он видно ардуинщик, если у него это звучит как "скечул"
@antonsergeyev
Жыл бұрын
Спасибо за отзыв. Но во-первых, schedule всё-таки пишется через "c". Во-вторых, есть 2 варианта произношения - британский "shehjool" и американский "skehjool". Возможно, вам просто ближе британский :) Кстати, посмотрел у вас на канале видео про esp32 - очень интересно и глубоко осветили тему. Я сам на нём программировал в магистратуре, но не знал всех тонкостей об устройстве железа 👍
"Треды большие и сложные, а корутины должны быть простыми."... Дальше слушать стало безразлично...
Всё хорошо, хороший доклад, но при чем здесь коммунизм про отнять и поделить?! Молодой человек хорошо разбирается в программировании, но ни черта не знает о марксизме, политэкономии и философии. Так вот поправлю юного подавана: "не отнять и поделить", а "обобществить". ;-).
@hardlabor9412
2 ай бұрын
🤡🤡🤡
Java надо учить а не go
@patrickjustice7371
2 жыл бұрын
слишком толсто
@bobsimple8291
2 жыл бұрын
нет, за php будущее
@user-bk5fz8wd9g
2 жыл бұрын
js
@user-zo2yd5dh2l
2 жыл бұрын
1С форева!
@ventilyator
Жыл бұрын
посоны переходите на питон