Release Party | Ways To Do Things with Peter Bourgon

  Рет қаралды 23,628

The Go Programming Language

The Go Programming Language

Күн бұрын

Пікірлер: 26
@rsjrx
@rsjrx 3 жыл бұрын
I became a fan of Peter after viewing another presentation he gave, where he was chased off stage when he was owed TWO MINUTES. Life is unfair. Peter has many great qualities though the ones I like the most are his immaculate hair, pragmatism and authenticity. Good talk.
@jamiebertram9744
@jamiebertram9744 4 жыл бұрын
"give more control to the caller" This is one of my favorite software idioms.
@jub0bs
@jub0bs 3 жыл бұрын
KZbin, how can I upvote this video twice? Behind a painfully generic title hides a great talk!
@VickyGYT
@VickyGYT 3 жыл бұрын
Concise, precise amd to the point. I like such well thought sessions.
@ramih6280
@ramih6280 5 жыл бұрын
Brilliant as always
@bminerrolltide
@bminerrolltide 2 жыл бұрын
Great talk. If you don't care about the first error that orchestrated the shutdown of your app, you can just make `net.Listener` context-aware. For example, one can start a goroutine in an anonymous func that reads from `ctx.Done()` and then calls `listener.Close()`
@kexuyo
@kexuyo 6 жыл бұрын
19:43 I wonder how to do error handling for all the goroutines here. It already needs so many chans just to cancel, so how to add error handling without adding too much mess?
@ddevienne
@ddevienne 7 жыл бұрын
Very elegant. Thanks Peter. My only concern is on the Group name which I find too generic. Does not convey the essence of what you came up with here IMHO. Here are a few alternate suggestions: ActorGroup.Add[Actor], Team.Add[Player], Orchestra.Add (with .Conduct() instead of .Go()), or finally Ensemble.Orchestrate(play, stop).
@tauraamui
@tauraamui 3 жыл бұрын
@24:16 in to the video, your actor launcher should have a channel wait receive within those anon go func calls which execute the actor, and after the loop the wait channel should be closed. Otherwise all of the actors will actually get launched one after the other, not at exactly the same time like that comment block was claiming.
@aarondavidcooper
@aarondavidcooper 3 жыл бұрын
concurrency is not parallelism
@tauraamui
@tauraamui 3 жыл бұрын
@@aarondavidcooper It's only ever parallel if it's running across multiple physical cores, otherwise it's concurrent/one after the other very quickly. That single line quote from the Go authors doesn't really address any points in my comment though, what's your point?
@aarondavidcooper
@aarondavidcooper 3 жыл бұрын
@@tauraamui The timestamp you provided states "Run all actors (functions) concurrently" which it does, so I replied as it looked like you may have confused concurrency with parallelism based on your suggestion. Sorry you didn't find it helpful, all the best.
@tauraamui
@tauraamui 3 жыл бұрын
@@aarondavidcooper Oh ok, so my point was just that the workers won't all start effectively at the same time, whether or not it's concurrent or parallel isn't part of the point I was trying to make. So if you want multiple routines to begin at the same time, you call them with the go invoke one after the other (because that's the only practical way to do that), but within the routines you immediately block them all by reading on an empty channel, but once they've all been Go invoked you then close that channel. When I said they don't all start at the same time, I wasn't referring to transparent difference between concurrent or literally the same time of parallism
@maybepeterbourgon
@maybepeterbourgon 3 жыл бұрын
Thanks for the comment. Even with a synchronization "fence" as you suggest, there's actually no guarantee the goroutines will start at the same time -- the scheduler is inherently nondeterministic in this regard! So I think there's really no practical difference between the current implementation and your suggestion.
@sneakdotberlin7085
@sneakdotberlin7085 4 жыл бұрын
I would like to put these snippets into a text repository I keep for ideas and inspiration and design patterns. Are these talk slides online somewhere or must I type them in from the stills onscreen?
@glxxyz
@glxxyz 3 жыл бұрын
The url at 22:45 wasn't quite right but it can be found here: github.com/oklog/run
@LuisRuizHalo
@LuisRuizHalo 4 жыл бұрын
Thank you, Skinny Pete.
@rodrigolessa8288
@rodrigolessa8288 6 жыл бұрын
What is the benefit of sending the processing to a separate go routine? The select statement still blocks so it doesn't seem that it makes the request any faster.
@dir01org
@dir01org 4 жыл бұрын
My initial thoughts exactly. But then I realised that this is a synchronisation pattern: rather than messing around with mutexes and stuff, we perform all of the operations in a designated goroutine in a sequential manner, so each operation has an exclusive undivided access to data
@wraytm
@wraytm 6 жыл бұрын
Genious.
@clever_taussig
@clever_taussig 6 жыл бұрын
Very useful!
@amanpshigh
@amanpshigh 6 жыл бұрын
Useful talk
@mhcbon4606
@mhcbon4606 7 жыл бұрын
+1 for Group, first 10 minutes are bit boring, overall very good talk
Golang UK Conference 2016 - Mat Ryer - Idiomatic Go Tricks
27:57
GopherCon UK
Рет қаралды 69 М.
IL'HAN - Qalqam | Official Music Video
03:17
Ilhan Ihsanov
Рет қаралды 700 М.
Gopherfest 2017 | Upspin with Rob Pike
31:18
The Go Programming Language
Рет қаралды 48 М.
Real 10x Programmers Are SLOW To Write Code
14:51
Thriving Technologist
Рет қаралды 69 М.
Premature Optimization
12:39
CodeAesthetic
Рет қаралды 846 М.
Gopherfest 2015 | Go Proverbs with Rob Pike
22:29
The Go Programming Language
Рет қаралды 262 М.
dotGo 2016 - Dave Cheney - Do not fear first class functions
18:55
dotconferences
Рет қаралды 29 М.
Dependency Injection | Prime Reacts
28:34
ThePrimeTime
Рет қаралды 363 М.