Super interesting talk. On the one hand, Lane asked great questions, listened patiently, and responded accordingly, without excessive talk about himself like quite a few young podcast hosts do these days. On the other hand, Jon is just insanely knowledgeable.
18:50 go was built with the mindset that not much would be added to the language. the tools naturally (pretty much had to) evolve with its adoption since there is a vested interest in improving the tools if the language itself is good. Bodner does a great job touching on the topic. 47:43 im also a type snob but still use python sometimes to switch things up. with type annotations and an LSP it's a much better situation now. ofc there's a difference between compile/runtime checking of the actual type safety though.
44:00 I think you CAN bundle go code as an embed.FS if you prefix the source directory with an underscore. The Go build system has some rules for what directories to ignore, for example if they're named "testdata" or "_*".
The pointer topic was mind blowing. Never thought about it this way, make it a nano sec. faster and debug for hours where what was manipulated, or simply "copy" the value, change it and return the "updated" value. Great stuff!
I actually just put Learning Go on my Amazon Wishlist and this video pops up. Cant wait to get into it. Good interview, love your content and your site Lane
the real replacement for "goto" is tail recursion. anywhere you have a for loop with a bunch of cases in it, you may have a Finite State Machine. Especially when writing tokenizers, tail recursion really helps to write code that matches the spec. you tail-call into a new state in the FSM.
16:11 I must object: if you find yourself fighting the language you might just be writing javascript lol Being a javascript developer for 20 years is like being that friend who falls into the most destructive relationships. I love super stable romantic life, but I like my programming language to surprise me with novelty. C/C++ is just hard, Python is always a black box with libraries and concurrency, Haskell is impractical, lisp is like an ideal that nobody but gurus can read, sharp and php depend so much on versions of language, Java has secret sauce jvm conflicts, and Rust is... Well, Rust is probably perfect if it didn't take so damn long to write/learn anything. But javascript is beautiful. Up and running in minutes, it glues to everything but is so fluid it can't tell you why it crashes. It's the affair that never ends.
19:25 Someone's building a bridge and they say 'I've got this new idea. I think it's gonna work. Trust me.' ... That's not my bridge. I'll take a boat.
I have actually been having a rough time trying to learn Go through the Go Tour right now - primarily because I keep asking "why this way" which isn't answered. It seems to me like I've been fighting the language and I'd benefit from reading Jon's book. Thanks for the pod, Lane!
Hey no one is forcing you to use spring, or annotations, or auto-wiring. Honestly seems like to me, this guy never read the documentations and just had some frustrating times with mixed configurations or whatever. As someone that's not even junior(no one employed me yet), I can see the benefits and drawbacks of this style of programming, and it seems quite useful in big corps where you have hundreds of engineers coding the same projects, you do want things to match welll and not have 1000 modules in different coding styles at least for the pipeline stuff that's absolutely mandatory.
"Using Go to do magic tricks"........ "I left Java because of the magic" This gave me a giggle. As a Java dev I hardly ever use inheritance. I use composition all the time. When it comes to performance, how can Java perform 6,000,000 financial trades per second on a single thread? Java is blazingly fast.
@@i-am-the-slime Used in financial trades as it's insanely fast. Also check out 1BRC (one billion row challenge). Reads 1 billion lines from a file, aggregates and then prints results in 1.5 seconds. Only language to beat it was C (but only just).
Re immutability and concurrency: what about using channels of a value type or an interface without methods to mutate the underlying data? I guess Go designers wanted to meet the needs of low level system programming as well as a keeping the language radically simple.
If you declare more than one bean implementing your interface spring won't start and your IDE will tell you about the conflict as soon you finish typing the conflicting implementation... at least he could have looked for a better excuse 😂
Spring is now LEGACY imo. Spring's DI is so OLD that it uses strings at it's core instead of tyes. Newer frameworks such as Micronaut and Quarkus do all the dependency injection at COMPILE TIME! These catch errors thrown by the annotation processors to be displayed in you editor (vscode/intellij etc). With these you can compile to native code as well (GraalVM). Unfortunately, many (uninformed) developers think that Java == Spring. I'm doing some AI/ML stuff in Java which offloads to SIMD instructions (AVX-256/AVX-512) without having to write the low level code. The JVM will detect what instructions the CPU supports at runtime and offload as necessary. Coming soon is the capability to offload to the GPU without knowing how to do CUDA/OpenCL. Exciting times and huge performance ahead.
I disagree... spring is a mature framework. It solves a lot of problems you don't have now but will definitely have down the road. furthermore the rise of nexJs and the continuous feature on-loading.... well just give nextJS a five more years it will become just as big or even bigger.
It's the worst shit ever. So is Java. Why is everything a class? "Runnable interface", really? Then binary incompatibility, semicolons, no higher-kinded types. The only people using Java are the ones that never tried anything else in earnest. The equivalent of people listening to Justin Bieber.
@@hardcorecode We've switch to HTMX. No javascript required. Just choose your backend language for your web app (Go, Rust, Java, Python). Take your pick :)
Super interesting talk. On the one hand, Lane asked great questions, listened patiently, and responded accordingly, without excessive talk about himself like quite a few young podcast hosts do these days. On the other hand, Jon is just insanely knowledgeable.
Really glad you enjoyed this episode!
Thank you sir, great explanation of stack and heap.
18:50 go was built with the mindset that not much would be added to the language. the tools naturally (pretty much had to) evolve with its adoption since there is a vested interest in improving the tools if the language itself is good. Bodner does a great job touching on the topic.
47:43 im also a type snob but still use python sometimes to switch things up. with type annotations and an LSP it's a much better situation now. ofc there's a difference between compile/runtime checking of the actual type safety though.
44:00 I think you CAN bundle go code as an embed.FS if you prefix the source directory with an underscore. The Go build system has some rules for what directories to ignore, for example if they're named "testdata" or "_*".
Looking for an episode for Leaving Go for Java
The pointer topic was mind blowing. Never thought about it this way, make it a nano sec. faster and debug for hours where what was manipulated, or simply "copy" the value, change it and return the "updated" value. Great stuff!
This insight was enough to convince me to get his book.
he didn't leave java. java let him go.
I actually just put Learning Go on my Amazon Wishlist and this video pops up.
Cant wait to get into it.
Good interview, love your content and your site Lane
thats google for you. lol
same thing happened with me lol
the real replacement for "goto" is tail recursion. anywhere you have a for loop with a bunch of cases in it, you may have a Finite State Machine. Especially when writing tokenizers, tail recursion really helps to write code that matches the spec. you tail-call into a new state in the FSM.
16:11 I must object: if you find yourself fighting the language you might just be writing javascript lol
Being a javascript developer for 20 years is like being that friend who falls into the most destructive relationships.
I love super stable romantic life, but I like my programming language to surprise me with novelty. C/C++ is just hard, Python is always a black box with libraries and concurrency, Haskell is impractical, lisp is like an ideal that nobody but gurus can read, sharp and php depend so much on versions of language, Java has secret sauce jvm conflicts, and Rust is... Well, Rust is probably perfect if it didn't take so damn long to write/learn anything.
But javascript is beautiful. Up and running in minutes, it glues to everything but is so fluid it can't tell you why it crashes. It's the affair that never ends.
I'm currently reading the second edition, it's great!
Great show.
Any chance you’ll do a Clojure guest? Maybe invite Rich? :-)
19:25 Someone's building a bridge and they say 'I've got this new idea. I think it's gonna work. Trust me.' ... That's not my bridge. I'll take a boat.
I have actually been having a rough time trying to learn Go through the Go Tour right now - primarily because I keep asking "why this way" which isn't answered. It seems to me like I've been fighting the language and I'd benefit from reading Jon's book.
Thanks for the pod, Lane!
Try "let's Go" you will enjoy that book much more and it guides you into a project. After that you can pick up this book
Thanks Lane for these amazing episodes. Please have AnthonyGG over for an episode, he's also a great Golang developer.
Bean Qualifiers solved that problem sir... but I agree it is a really annoying problem to have to solve
I compile PureScript to Golang. That's fun. Higher kinded types, rowtypes, lenses and monad transformers. So good
Hey no one is forcing you to use spring, or annotations, or auto-wiring. Honestly seems like to me, this guy never read the documentations and just had some frustrating times with mixed configurations or whatever. As someone that's not even junior(no one employed me yet), I can see the benefits and drawbacks of this style of programming, and it seems quite useful in big corps where you have hundreds of engineers coding the same projects, you do want things to match welll and not have 1000 modules in different coding styles at least for the pipeline stuff that's absolutely mandatory.
Come back to this comment in 5 years 😊
"Using Go to do magic tricks"........ "I left Java because of the magic" This gave me a giggle. As a Java dev I hardly ever use inheritance. I use composition all the time. When it comes to performance, how can Java perform 6,000,000 financial trades per second on a single thread? Java is blazingly fast.
It's not
@@i-am-the-slime Used in financial trades as it's insanely fast. Also check out 1BRC (one billion row challenge). Reads 1 billion lines from a file, aggregates and then prints results in 1.5 seconds. Only language to beat it was C (but only just).
Those were said in completely different context. You are being purposely facetious
Amazing 🤩
I didnt leave Python it slithered away, and a Gopher popped up.
Re immutability and concurrency: what about using channels of a value type or an interface without methods to mutate the underlying data?
I guess Go designers wanted to meet the needs of low level system programming as well as a keeping the language radically simple.
26:18 that is straight up dumb brother 😂
Learning Java now to do QA work. Maybe I should just stop now. 😂
Lots of new stuff coming along in Java. Quite an exciting time. Avoid Spring!
If you declare more than one bean implementing your interface spring won't start and your IDE will tell you about the conflict as soon you finish typing the conflicting implementation... at least he could have looked for a better excuse 😂
Spring is now LEGACY imo. Spring's DI is so OLD that it uses strings at it's core instead of tyes. Newer frameworks such as Micronaut and Quarkus do all the dependency injection at COMPILE TIME! These catch errors thrown by the annotation processors to be displayed in you editor (vscode/intellij etc). With these you can compile to native code as well (GraalVM). Unfortunately, many (uninformed) developers think that Java == Spring.
I'm doing some AI/ML stuff in Java which offloads to SIMD instructions (AVX-256/AVX-512) without having to write the low level code. The JVM will detect what instructions the CPU supports at runtime and offload as necessary. Coming soon is the capability to offload to the GPU without knowing how to do CUDA/OpenCL. Exciting times and huge performance ahead.
I disagree... spring is a mature framework. It solves a lot of problems you don't have now but will definitely have down the road. furthermore the rise of nexJs and the continuous feature on-loading.... well just give nextJS a five more years it will become just as big or even bigger.
Spring is great. People need to git gud
It's the worst shit ever. So is Java. Why is everything a class? "Runnable interface", really? Then binary incompatibility, semicolons, no higher-kinded types. The only people using Java are the ones that never tried anything else in earnest. The equivalent of people listening to Justin Bieber.
@@hardcorecode We've switch to HTMX. No javascript required. Just choose your backend language for your web app (Go, Rust, Java, Python). Take your pick :)
Bruh it is so creepy how you stare into the camera
I do it for u
lol I don’t think it’s weird. Thanks for the quality content man!
😂@@backendbanterfm