no, blue hair = rust developer. He had to switch to Go otherwise he would be trans by 2025
@sutirk11 ай бұрын
Dyed hair blue to become a real rust developer, ended up identifying with the gopher so much that golang is his main language now
@justanothercomment41611 ай бұрын
@@AJewFR0 The Foundation is clearly suffering from it.
@susiebaka338811 ай бұрын
Blue hair is rust bro 😅
@justanothercomment41611 ай бұрын
@@susiebaka3388 Yep. So is the agenda.
@taylorallred620811 ай бұрын
I’ve really come around to Go. I used to despise it but now I’m in love with the simplicity. In Go, I find myself asking “what is the most straightforward way to do this?” And more often than not that is clearly the best approach.
@ThePrimeTimeagen11 ай бұрын
There's something very beautiful about this. When there's often only one path available, you just don't have to think too hard about the minutia
@RossDmoch11 ай бұрын
@@ThePrimeTimeagen ewww, that sounds like python. Gross
@susiebaka338811 ай бұрын
@@RossDmochpython is a lot different from golang 😅
@joshduffney795411 ай бұрын
@@susiebaka3388 WAYYYYY different
@jibbscat514611 ай бұрын
Is python known for doing everything one idiomatic way?
@sfulibarri11 ай бұрын
Imo, most people who like rust actually just like having native Option types and exhaustive pattern matching; just those two things solve something like 97% of bugs in most projects in mainstream languages just by getting rid of exceptions as control flow and forcing you to handle all cases. Beyond that, most of its features exist to address a specific kind of complexity that just isn't present in most software engineering contexts.
@keyboard_g11 ай бұрын
Prime C# dev 2025. Lets go.
@akshay-kumar-00711 ай бұрын
C# .NET ftw
@Kdefthogbg11 ай бұрын
Context always matters, I think he's not challenged enough. Also C# NET ftw :')
@kattankarl11 ай бұрын
This the arc we're all waiting for Visual Studio Enterprise C#
@aj-jc4cv11 ай бұрын
C# is like a duvet
@xelesarc168011 ай бұрын
C# is hot u know today
@thaddaeusmarkle166511 ай бұрын
"complexivityness"... Learned a new word today
@creativecraving11 ай бұрын
😂 That's a generous way to say it!
@gokulakrishnanr841410 ай бұрын
Nice find! 'Complexivity' is a great word indeed 🤓
@chillbro22754 ай бұрын
hahah oh man, if i wasn't already subscribed, that line would've gotten the sub.
@sawertynn63083 ай бұрын
Now we need the adjective for that: complexivitynessfull And ofc the noun complexivitynessfull ness
@k0rnburn11 ай бұрын
I like D because it has both sides of the coin somewhere in-between of Go and Rust: you can start writing in a simple way very clean and fast with GC and simple structs.. And if you need to make some tricky magic - welcome to metaprogramming world with traits, mixins and templates. If you need even more speed - you can even disable GC and write your hot part with asm and great auto-vec support from GCC/LLVM world.
@vladyslav18 ай бұрын
A pity that Go has a lot more drive behind it from employers
@thesaintseiya11 ай бұрын
Love your take here, as a relatively new dev I'm currently learning Go and loving it, but I'm super excited about learning Rust next year. I love this idea of dedicating time, like a full year or two, to explore and get good at different paradigms and that's what I'm doing
@re_detach11 ай бұрын
Go is my goto language because it goes
@patrick_jane11 ай бұрын
Where does Go go?
@user-qr4jf4tv2x11 ай бұрын
@@patrick_jane its going no where for prime
@AdamFiregate11 ай бұрын
TypeScript, Go, Rust. Polyglot programming.
@re_detach11 ай бұрын
@@patrick_jane the places Go goes continues to grow as time goes on
@OnFireByte11 ай бұрын
Rob Pike knows Go is the go to language for a lot of people to the point that he has to put goto keyword in it
@markhaus11 ай бұрын
I think this is a pretty great way of going about learning about the mysteries of how humans and teams of humans think about programming. Most languages have unintended consequences as a result of certain design decisions that eventually become crystalized and hard to avoid as it matures. I don't think a lot of people really know if the amazing expressivity and less than amazing complexity of rust affects the human behaviors of programmers working with it without trying something completely different like Go. I'll be following along and will be very curious what some of the unintended consequences of the decisions made during Go & Rust's development get uncovered.
@quasi_verum10 ай бұрын
I am with you.
@gokulakrishnanr841410 ай бұрын
Interesting perspective! Rust's expressivity vs complexity impact on human behaviors is a fascinating topic. Looking forward to your insights on Go's unintended consequences.
@scofield11711 ай бұрын
“Your app having complexity that is unmanageable is a skill issue” amen brother
@no_name479611 ай бұрын
Living is a skill issue
@binpax548310 ай бұрын
Thought he said a scale issue
@gokulakrishnanr841410 ай бұрын
Agreed! Modal design can be tricky. Here's a simple fix: .modal { width: 400px; display: none; position: fixed; bottom: 20px; right: 20px; padding: 20px; background: #f9f9f9; }
@yugioh881011 ай бұрын
I feel like lots of Go programmers are ex-java programmers who have never did professional programming outside Java (like yours truly) and once they did the shift to go they were impressed by the simplicity of the language, bear in mind half of java is spring boot with all it's features and complexity so it adds more to the complexity and abstraction you have to deal with.
@gokulakrishnanr841410 ай бұрын
Ah, I see! Many Java devs find Go's simplicity refreshing after dealing with Spring Boot's complexity. 😊
@egorsozonov74258 ай бұрын
That’s my case. I’m a Java dev and I feel alright about Java itself, but this obsession with that awful Spring thing is just sick. Spring is a monster gobbling up your development time, totally broken and undebuggable, and Golang is a refreshingly beautiful ecosystem in comparison. One of the best things about Go is that there’s nothing like Spring there
@aeggeska15 ай бұрын
I came from Java, Python, JavaScript, and I just can't for the life of me figure out pointers. It makes no sense.
@Bot-on-Tapwater5 ай бұрын
@@aeggeska1 You should try C first, C is very plain and has very little things to learn. But it teaches pointers well.
@notpugal3 ай бұрын
Hey. I want to get placed in a job and also want to contribute to opensource.Can you tell Which would be good.. Java or go
@HumanoidTyphoon9111 ай бұрын
Commenter: Just use whichever language makes you happy Prime: TRIGGERED
@gokulakrishnanr841410 ай бұрын
Haha, I see what you did there! 😂 Thanks for the feedback!
@scillyguy11 ай бұрын
"This chisel is a rubbish hammer"
@gokulakrishnanr841410 ай бұрын
Sorry to hear that! 😞 Can you tell me more about why you think it's a rubbish hammer?
@_MrKekovich11 ай бұрын
I really like how there's a word "brain" in his transparent head on 5:40
@gokulakrishnanr841410 ай бұрын
Nice catch! 🤯 That's a clever design choice.
@davidcoulton90216 ай бұрын
Too good timing.
@Julzaa11 ай бұрын
Looking forward to it! I've been gobbling up your Go content
@SVVV9711 ай бұрын
Gobblin up the GoC
@AScribblingTurtle11 ай бұрын
Go is pretty fun. Cool, that you give it a serious chance. I love it for prototyping and testing new Ideas. You don't have to worry to much about types, to get things working, but once you want to tie things down, you can type things as strict as you want. The only hard thing to wrap my head around was slices. Once I realized that a Slice that is extended over its original capacity becomes a list of clones instead of references, everything was OK though. Until you extend a slice over its original capacity, all elements in it are references to the original entries, allowing for some pretty fun stuff, when building multiple slices from the same base Array.
@Rakstawr11 ай бұрын
I think that depends how you are extending the slice. It's just a pointer to an array plus a size...
@AScribblingTurtle11 ай бұрын
@@Rakstawr there is an append function, it returns a new slice. Append to a slice, whos capacity has not been reached, and you get the original slice back, just with the new element appended. However, if you append to a slice whos length is equal to its capacity already, then Go creates a new slice, that contains copys of the original slices contents + the appended element and a new capacity. instead.
@YannSchmidt11 ай бұрын
I understood slices much more as I used them in Python and there is a lot of .
@sohn776711 ай бұрын
@@AScribblingTurtlethe capacity isn’t referring to the slices, but the underlying array. Slice is really just what the other user described
@ronny58411 ай бұрын
@@AScribblingTurtleI mean it's pretty obvious. Slice is just a reference to an array. And an array is a continuous block of memory, so if you append and it exceed the memory, you can't just put it in, it will override some memory blindly. So you have to create a new one.
@hakooplayplay321211 ай бұрын
Prime, you actually one of the reasons iv switched from being node.js developer to Golang dev. Im happy and want to thank you!
@porfiriodev11 ай бұрын
I'm kinda of migrating from PHP and Laravel to node because of a job and I'm really enjoying it. But I'm thinking about giving Go a try to see if I like it. The thing is, there are some details that scares me like pointers, bc I did not had a great time learning that on college lol. I wanna see if Go is all that great like everyone talk about
@hakooplayplay321211 ай бұрын
@@porfiriodev pointers in go is simple, you don't need to think of them too much, because of garbage collector. Just understand what it is and when to use it and that's it
@gokulakrishnanr841410 ай бұрын
Wow, thanks for the kind words! 😊 Glad to hear that my content has inspired you to switch to GoLang. Good luck with your new journey! 🚀
@unl0ck99811 ай бұрын
Type masturbation is hilariously accurate
@Dolanor10 ай бұрын
Yep, felt real
@gokulakrishnanr841410 ай бұрын
Nice! Here's a suggestion for the background color: #f9f9f9.
@bohdanivanchenko52629 ай бұрын
It’s not
@justadude87163 ай бұрын
type masturbation addict above ^
@JerredWernke11 ай бұрын
I have been writing php code for years. I starting to use go whenever I can because of how simple it can be to learn and all of the powerful choices it has made for a language go is really good and I want to find a way to write more Go code.
@pldcanfly11 ай бұрын
I came from learning CS (with C, Java, C# and all the things) to do mostly PHP, some Ruby and ELM in between and a lot of JavaScript until I started to like TypeScript. Now Go is my main-language whenever I can. My first projects where pure chaos, since I was still stuck with JS-brain and trying to solve stuff that way. The more I looked at how go-devs solve stuff the go-way the more I embraced that, and now stuff feels so extremely elegant in it's simplicity. Combined with HTMX it's just beautiful.
@enzocam0710 ай бұрын
What kind of projects do you do in Go, I am starting learning but I don't have idea what to build because my mind is so immersive in Frontend but I need a change
@pldcanfly10 ай бұрын
@@enzocam07 I started with some simple webservers. Replicated a few things I did in JS. Then I focused on a smart alarm. A replacement for an alexa echo dot with a raspberry pi underneath. What I also want to are some GTK-Desktop apps. Mainly to fill in blanks in my workflow I haven't found tools for that I like, and to learn a bit more about desktop-programming. Even tho go might not be the best for that, it still is better then electron.
@mauricioramirez285510 ай бұрын
Impressive your journey. What’s the the main or top 3 ups of go compared to the other languages you handled?
@pldcanfly10 ай бұрын
@@mauricioramirez2855 I just like the language which helps. But if I had to pick... Errors as values, the standard-library, and simplicity. honorable mention to god-tier concurrency, BLAZINGLY(tm) fast compiles and the elegance with which you can solve a lot of things.
@potatoes_fall11 ай бұрын
I remember discovering your channel and being appalled that you were bashing Go. You've come so far ❤
@gokulakrishnanr841410 ай бұрын
Wow, you've come a long way since your early Go-bashing days! 😊
@WorldofMillenial11 ай бұрын
When you write stuff in GO you are thinking about program you are doing, when you write in RUST you are thinking more about language and less what you want to achieve. This is dealbreaker (at least for me) when it comes to productivity.
@murtazarizvi60511 ай бұрын
Similarly true for java and c# as well.
@baxiry.11 ай бұрын
100%
@creativecraving11 ай бұрын
I actually find Rust has less of that problem for me than Haskell. It's because the type system is slightly less expressive, at least, without macros. However, in C# I find myself spending too much time wondering what the simplest way to do something is, because it's so low-level that the simplest way to do something often looks complex. So it ends up being a different kind of type masturbation. I'm very happy with Rust so far. (I started using it this year.)
@dexusint6 ай бұрын
Same with modern c++. Main reason why I switched to Go
@zz1965Serg3 ай бұрын
Если среди разработчиков чувак придумавший ( со товарищи) чистый С и Unix, то go по определению не может быть говном! Жаль что чуваки сразу не подумали что модель исполнения (все статическое) + goroutines отлично подходит для baremetal микроконтроллеров софта. Но вроде наконец появился tinygo.
@joelazaro46111 ай бұрын
Reminds me of the crazy types I would see in TS when I would mouse over a variable in a React app. I watched some of Matt Pocock's TS videos a long while back because I wanted to get better at types, but I kept wondering "Is this level of complexity really necessary?" I've been building a project in Go and the simplicity feels so worth it. I still catch myself overengineering things and have to dial it back when I refactor.
@einargs11 ай бұрын
A lot of the crazy typescript types are necessary to type the things people are used to doing in JavaScript. You can do basic classes and data types and only do that if you want, it's just that people are used to certain (more convenient) patterns from JavaScript.
@Gohealt10 ай бұрын
Matt Pocock is trying to polish a turd , and guess what? It’s still a turd!
@gokulakrishnanr841410 ай бұрын
Ah, fellow over-engineer! 😅 Go is great for simplicity, but we all struggle with it. 😅
@fr0xkАй бұрын
Go builds and runs on almost anything-any OS, any architecture. It cross-compiles from anything to anything, statically links during cross-compilation, and doesn't care about glibc, bionic, or GPL drama. It has a built-in concurrent garbage collector and comes with everything you need out of the box, handling 90% of what C, C++, or Rust can do without the headaches.
@ehfoss11 ай бұрын
I think Go will help your Rust since it will help you surface simple designs. I think this is how Tower came about. Before Tower, Rust web libraries were proc macro all the things, over complicated messes. They're powerful but if you get compiler errors, you need to use your galaxy brain to figure out what the heck happened. Well I'm sure someone saw how Go's handlers work and this completely inspired Tower and it's very simple and straight forward and composable.
@xotmatrix11 ай бұрын
I did one big project in Golang and had a wonderful time. The suck started when using a graphics/sound library that had terrible performance. I kinda feel like giving it another go (hur-hur) after last year's C# excursion. I should give Rust another attempt but Golang is so much more comfy.
@ThePrimeTimeagen11 ай бұрын
Perhaps that's where you shouldn't use the language. It is a language designed for the web, writing servers, and clis. So using it outside of that bounds I'm not exactly sure where it fails
@amodo8011 ай бұрын
@@ThePrimeTimeagenebiten is a pretty nice game engine for go, though.
@Pabloparsil11 ай бұрын
Maybe try raylib with the go bindings?
@xotmatrix11 ай бұрын
@@Pabloparsil Maybe! I've been following it for a while and want to try it. Do you have experience with it and Golang?
@xotmatrix11 ай бұрын
@@amodo80 It's OK but it gave me a lot of pain actually. That's the library I was referring to. The shader system is kinda bad and dynamic audio synthesis is extremely laggy.
@Khari9910 ай бұрын
I've been debating between switching from TS/JS to Rust, Go or Elixir and I decided to go with Elixir and I'm over the moon with it. I didn't think i'd like it as much as I have. Functional programming and the actor concurrency model has completely changed how I go about solving problems. It may not be as performant as Go or Rust but I write better structural code with it. Its understated how much of a quality of life improvement that has had that I was not expecting at all. There are also packages like Rustler that allows you to use Rust directly in Elixir if you need performance critical operations. I don't see myself leaving the language for quite some time.
@himboslice_3 ай бұрын
I can't get over the fact everyone is using Phoenix for building web APIs even w/o liveview, and the amount of boilerplate it generates.
@FeistyFugu11 ай бұрын
I love this take. I write C# at work. How many times have I debated with colleagues whether such or such code should be an extension method, an abstract class or whatever else the language provides. By removing these options, Go shuts down all this useless chatter.
@gokulakrishnanr841410 ай бұрын
Thanks, glad you enjoy! C writing is awesome 😊
@Feynt7 ай бұрын
I definitely agree that there is no best language, there is just the best language for the situation. Sometimes it's a language you don't know yet. Insisting that there is only one good language is like saying welding is the only way to join two things, and if you can't weld those things you're using garbage materials. And then, a classical Japanese woodworker casually drops off a joined set of beams and says, "this survives a 6.0 earthquake in a 4 storey house" and walks away. No glue, no nails, no screws. Always be learning. Other languages exist because they solve a problem that existed when they were made. Sometimes they jump the shark and are brought where they shouldn't (looking at you, JavaScript), but there's still the core concept in mind, and you will know that it's the right idea to solve your problem when the time comes.
@BosonCollider8 ай бұрын
9:05 This is where the ease of learning Go is amazing, because introducing it to your team is a relatively easy way to escape a worse language by starting work on a new project in Go. Stuck in the hell of using dynamic programming languages for large projects, or of using them for applications that need performance? Go is an easy sell and is so much nicer to work in.
@chillbro22754 ай бұрын
7:52 hahah, that's funny because i'm just barely starting Go, and the thing I don't like is the := thing. I just don't like way it looks haha. I feel ya man.
@Cahnisama11 ай бұрын
00:41 loses only to typescript right? RIGHT?
@alexvass11 ай бұрын
Thanks
@Me-wi6ym11 ай бұрын
I disagree slightly that using languages you really like gets you stuck using only that one or its associated paradigm. Personally, I've been having a TON of fun using Scala as my main language lately because I just like the way it feels (it has a lot of similar features that I love from Rust, but without the memory management), but when I need a more functional language, I tend to immediately reach for F# or Elixir (depending on what is needed for the project). If I want to practice OOP, I tend to use C#, Kotlin, or Ruby. Lower-level stuff gets Rust, C, or Go. I think you get the point... For me, using those different languages was a way *to break into* new paradigms, not get stuck in a single one. In fact, a lot of times I get really bored if I have to use the same language for a lot of projects in a row. I dunno, maybe I'm the outlier, but I just think it's neat to see how different languages handle similar (and also different) scenarios.
@SileySiley-dh5qz11 ай бұрын
"but when I need a more functional language, I tend to immediate reach for F#", clever guy! 😉
@Me-wi6ym11 ай бұрын
I mean, Scala can handle functional programming just fine. My point was just that if what he was saying was entirely true, I would've just stuck with the one language over choosing several. Also, unrelated, thank you for bringing my attention to a typo that I missed!
@SileySiley-dh5qz11 ай бұрын
@@Me-wi6ym I meant that as you use F# you are clever guy. I didn't notice the typo. F# is a very good language. I started using it 2 months ago and migrated immediately a lot of my C# code to F#. C# is a little bit too verbose (Java heritage) and I like a lot the functional approach in coding. Having all the .NET ecosystem available when using F# , its great operability with C#, its great transpilers (Fable) make it a very good choice.
@complexity554511 ай бұрын
Its really a expression of the individual. Prime's telling on himself and how his brain works. It is very transparent of him to expose himself like that. I've seen these brain types before. They lock on to an idea and go full ape. But prime has learned to tame that ape. The ape brain can self reflect real good now. Some programmers (or humans) hate switching paradigms or modes. Their brains literally don't have the idea hopping genius and correlation. It takes time for their brain to build up neurons that can grow at will.
@Me-wi6ym11 ай бұрын
Ah I see. I assumed you were mocking the obvious choice of F# for functional programming since that's what it was designed for, my mistake. I personally love F# and it makes me kind of sad how little it actually gets used in the job market. I wish Prime would try it; the syntax is almost identical to Ocaml, at least for the important parts (if I'm remembering right, they handle OOP differently, but you don't use those languages for OOP anyway). I'll bet he would actually really like it
@kinsondigital5 ай бұрын
C# is amazing. I find myself spoiled by C# and its ecosystem. I move to other languages and miss C#. But I have been starting Rust and am building a client project with it. But I think I am going to start with Go. Flexing my brain is why I want to do this!
@ryanslab30211 ай бұрын
Go for me this year, too. I’m taking your Go and HTMX lessons and other Go lessons on Frontend Masters.
@ducksies11 ай бұрын
I find myself often writing really verbose workarounds for simple expressions in other languages. I think something that writes like Python with the speed of Go would be the best. For me, Python is the closest language to imperative paradigm pseudocode.
@creativecraving11 ай бұрын
Hmm. Could that mean you're not writing idiomatic Go code, yet? Translating from English can result in long, awkward phrases; and the same is true when translating into English, too
@aidanbrumsickle11 ай бұрын
It's funny how things don't feel verbose until you realize there's an alternative. When I was doing primarily Go for a while in 2017 - 2019, I really missed having either something like list comprehensions, or map/filter/reduce. And yet I had spent years happily writing for loops in C and pre-Streams Java.
@ducksies11 ай бұрын
@@creativecravingfor example, take a simple ternary operation. x = 2 if thing else 3 in go this becomes x := 2 if thing { x = 3 } Lots of small things like that cause a great deal of mental friction while writing simple code
@YaroslavFedevych11 ай бұрын
You refute the thesis that “complexity is either in the language or the application is a dumb take” by telling how generics led to simplifying code everywhere, including Go’s standard library. Previously, Go authors were very much against generics, then they were putting them off “to make them just right”, and now they have it and it has simplified lots of things. So I guess the take is not dumb, it’s true in fact, but it has limits. Like when you have essential complexity you cannot reduce further without detriment to solving whatever problem you are trying to solve. There’s _also_ a lot of unnecessary, self-inflicted complexity. Who knows, maybe using just a little bit of inheritance and java-style exception handling could simplify even more things? Maybe not, but what if? Or should we be uncritically burning heretics for merely uttering the forbidden keywords?
@konstantingeyst4568Ай бұрын
Go devs weren't against generics, it's a myth. Their site, since 2013 , said they wanted to add them, but had no idea how to make them simple
@agusaris503111 ай бұрын
Genius adores simplicity over complexity
@aodhai11 ай бұрын
rust allows simplicity to mask complexity in a very nice way
@pianissimo712111 ай бұрын
When you are a genius, stuff looks simple which is actually complicated. Obviously not true for all cases but I have seen it happen a few times.
@atiedebee102011 ай бұрын
@@aodhaiC++ allows simplicity by basically coding in C
@getthezeppout11 ай бұрын
The more time I spend using Go the more I find interfaces really elegant. Refactors and testing become a breeze and they make the code feel super nimble
@joan383 ай бұрын
5:44 We gained union types in Scala and I can only disagree. Together with singleton types we can have types like `"lts" | "exp"`. Do I need an interface or an enum just for that? Well you just said that a simple language does not mean complex apps. But now it's proving the point that I need to make my app more complex because the language does not have that feature.
@kuhluhOG11 ай бұрын
Imo one should try all combinations of high-level vs low-level and simplistic vs complex with at least one programming each (so yes, at least for PL). Obviously they shouldn't try all at once and from the get-go (and in general a starter PL shouldn't be a complex one, beginners already have enough other stuff to deal with (you would be surprised at how many people struggle with understanding the concept of recursion in the beginning)), but over time one should do this. And after having a decent amount of experience in each category, then go and start judging them against each other, but don't be surprised if not everybody agrees with your conclusion.
@__TClol__11 ай бұрын
I started in TypeScript. I learned Go as a job requirement. I now write better TypeScript because of conventions Go introduced/enforced.
@insidiousmaximus8 ай бұрын
Ive been an AI and game dev for 6 years and this is so accurate. I learned to like each language the way it is. Even down to colour tbemes. I use jetbraind ides and python c# and javascript is what i use mainly and each one i have a different colour theme that somehow suits the langauge for some reason and im pedantic in each one respectively about its own syntax and styling. This just happened over time with using then all enough for different tasks.
@robonator294511 ай бұрын
As much as I hate the self-serving fanboi-ing over a language, I really think these sorts of arguments miss why people like Rust. I hate the foundation, mozilla, etc. and have every possible reason to be biased against Rust, but at the end of the day when I first began using it it *_felt_* like how programming *_should_* feel in my head. Same thing happened when I switched to Linux, it *_felt_* like how a computer *_should_* feel in my head. It had the features I never even questioned why they were missing, it removed the flaws I never even questioned why they were there, and it gave me flexibility I never even knew I didn't have. When I try to do something in Rust and find myself fighting the compiler, (note : that isn't always the borrow checker either!) I invariably find out at some point during the debugging/research process that what I was trying to do had more complications that I wasn't aware of previously. Not in the stupid "XY problem" way which is just used as an excuse to avoid answering the question that someone actually asked, but in the "oooooh, that makes sense why I can't do it this way, it's not possible" way. For instance, I don't do "hello world"s, I just don't, I've never found them useful to learning a language, so for my first project in Rust I tried to do a little embedded LED blinker project with an Arduino and had issues assigning arbitrary pins to be used to drive the LED. This wasn't a real issue for the project mind you, but I was cobbling things together from different sources and noticed that they didn't cleanly click, so I wanted to implement it fully and 'right'. In the process of making that very simple blinker I learned about impls, dyn traits, etc. and, after more work looking into embedded, I have a much clearer picture of why what I was doing wasn't easily possible. (of course I don't know for *_certain,_* but typically output pins are memory mapped or otherwise 'linked' as one unit that you assign values to collectively, sort of like output pins in a shift register. To that end, of *_course_* you couldn't just pass in completely arbitrary pin numbers, because the math to get a 1 or a 0 in that specific position is different and requires different instructions) Debugging pre-runtime (not necessarily even comp-time) just *_feels_* right, you generally have some assurances, you can speak about your code with confidence, and you can, generally, be sure you understand what's going on with your code, or rather, you can be sure that you don't *_not_* understand anything going on with your code. As a language these aren't magically intrinsic benefits - and yeah, sometimes it's annoying and feels like you're having to beat your head against the wall to do even a basic task - but at the end of the day *_knowing_* you didn't, intentionally or otherwise, take any shortcuts and that you're final result *is* comprehensively valid is invaluable. Your final result works, and you can say that with confidence. If, for some reason, there *_are_* any esoteric bugs, it's either a problem with someone else's code or it's isolated to your very clearly designated unsafe blocks. When you're making small throwaway utilities that's not meaningful, but when you're making a project or even a full application? Yeah, that matters. There are times you want types, and there are times where god damnit you just want to assign an ASCII character to a bloody i32 for some reason. If you're making quick throw-away applications or something then yeah C or Go or some other "get the fuck out of my way" languages are good, but that's not what most people do. "Minimum viable product becomes production", and with Rust you literally cannot help but make MVP at least production grade because the compiler wont let you.
@ITSecNEO11 ай бұрын
Yes, people who dont understand what advantages we have with Rust are just blind and dont give Rust a chance.
@arobie9211 ай бұрын
I recently did some programming in Haskell to get a feel for it, well technically PureScript but same thing for all intents and purposes, and had the same experience, modulo massively better error messaging in Rust. I'd run into an error, spend a bunch of time trying to figure out why it was complaining and swearing at the compiler only to realize I messed something up or neglected to consider a possibility-at least Rust is nice enough to even suggest fixes. Once I accounted for that possibility or fixed my mistake, everything compiled and the app ran without any errors. There's plenty of other languages from dynamic ones like Python and JS to even just weaker static type systems like Java and Go where it runs but either doesn't output the right result or what seems like an innocuous change causes all kinds of issues that seem like they came out of nowhere but actually just lucked into not being hit. I do think Rust is overkill for a lot of projects since many don't need deterministic memory management, but there's a ton to be said for the compiler keeping you honest and informed. If I could have a GCed language with Rust's level of error messaging and as conscientious a compiler, that'd be my go-to language in a heartbeat.
@brinckau11 ай бұрын
Got the same feeling with assembly language. Code in assembly feels like a true computer program, you don't need to have it rewritten by some compiler. It's perfectly aligned with how the computer works. It's not hiding anything. It makes perfect sense.
@robonator294511 ай бұрын
@@ITSecNEO I mean I'd argue Prime has 'given it a chance' as much as anyone can be reasonably asked, I just don't think he's used it in the way most people will or will want to. To me at least, Rust's one big advantage is it's explicivity. Both the compiler *_and_* future readers of your code (yourself included) can clearly and confidently know what it's saying, what it's trying to say, and if/when those two things don't match or might not match. (within reason) The compiler then takes that information and *_forces_* you to either rectify the problems or mark the parts where you smeared your shit against the keyboard and told the compiler to make it be a program today and someone else's problem tomorrow. (which, as I'll hopefully reinforce sufficiently later, isn't necessarily always the wrong route - not all code *_needs_* to be provably production-grade) When you're writing command-line utilities and the like (which Prime explicitly said is what he used Rust for) then that *_will_* just get in the way more often than not. The loosey-goosey typing and lasseiz-faire semantic rules of something like Python, Javascript, Go or C are excellent for niche little utilities that need to just do a job, do it reasonably well, and not take a ton of time to make. Rust's main value, at least as I see it, is that it forces you to have better practice than that though. Not in the "oh well this is more clean and idiomatic" way, but rather in the "where the *_fuck_* do you want me to put this string?! Do you want it on the bloody stack or the damned heap FFS?!" way that forces you to understand and reason about the things you're actually asking the computer to do. This means you can be (reasonably) confident that your final product is solid and robust, at the cost of requiring much more (and much lower-level) reasoning. Rust *_is_* (likely) more of a hinderance for the problem-space Prime used it in, and I don't think that counts as him 'not trying it'. I *would* agree that I don't think he's really understood why people value it, but I wouldn't say he hasn't tried it. I just think his usecase for it is rather niche in comparison to what most people would use it for, and he hasn't really thought beyond that application-space. (which, to be clear, I *would* still say is a flaw on his part, but speaking without realizing other people's perspectives is far less of a problem than speaking without even realizing your own perspective first.)
@jly_dev11 ай бұрын
There was no blue hair dye, Prime became a gopher naturally
7 ай бұрын
Your description of Rust is very close to how I felt when I was into Scala. I ended up ditching Scala for Go and never looking back.
@michelfeinstein11 ай бұрын
After I transitioned to Flutter I found weird how simple Dart is, now I love it.
@BloodEyePact11 ай бұрын
I'm also more or less all-in on Go at this point, but to the point about enums, interfaces and enums are complimentary. Enums are great when when you need a fixed number of data options, but unbounded behavior options, while interfaces work when you have unbounded data, but a fixed number of behaviors. Interfaces are great for representing things like streams, which go does, but awful for representing deeply nested data structures, such as syntax trees. For this reason, I believe enums would actually be a valuable addition to Go. They added generics, so anything's possible.
@nano_sweetАй бұрын
At the end of the day, I find it joyous just to be able to learn new programming languages. It feels like I'm taking a peek into the brilliant minds that created them: a whole new universe to explore!
@orcofnbu10 ай бұрын
I'm switching to go too. İ need something modern and well designed. But most of new languages are very strict and complicated to start or worse they force to use a specific framework. i like go's philosophy
@johnathannichols23711 ай бұрын
Go is great for backend webby stuff. First class language for backend web development and very nice for CLI. However, I would never use it for high performance or system programming. It's a language not designed for those areas. As a C programmer, I love Go. So for all you webby folks, if you do Go on the backend, native JS on the frontend, and use websockets to connect both sides, your website/webapp will require minimum if any 3rd party dependencies.
@avalagum795711 ай бұрын
I know nothing about Go. I know C but just the single-threaded C, not multi-threaded. How does Go solve the issue that Rust's borrow checker solves?
@snikta5642 ай бұрын
Is there any flavor of rust that disables syntactic sugar and fluffy features? I.e. if I basically want C with borrow checking and Rust compatible syntax?
@hirashiki.rafael5 ай бұрын
Parts of what was mentioned in this video confirmed me even further that learning programming languages is not much different than learning culture languages. Gotta think in that language in order to succeed more than thinking on your mother base language and keep translating. Meaning can get lost easily.
@sid__art_661411 ай бұрын
i have only one question why are people choosing go or rust over c or cpp? What am I missing. i mean if c and cpp is fastest what else you need that go or rust are doing better.
@igoralmeida913610 ай бұрын
go is far easier than c++ and rust is for bragging rights
@hypnogri545710 ай бұрын
speed isnt the most important factor depending on the situation
@luiscarlosjayk10 ай бұрын
There's a nice quote I like: "Programming languages are tools, not religions"
@GetAnAndroid11 ай бұрын
Funny you mention the if statements and snake case being a turn off for Rust initially. The one and only time I tried learning some Go a few years ago, I discovered the compiler forces opening braces to be on the same line. I use new line curly braces, and I hated Go forcing new line upon me so much I quit after the first exercise and haven't revisited the language since.
@shellderp11 ай бұрын
this week I found out go doesn't even have immutability
@georgespanos468010 ай бұрын
Bill Kennedy recently said that Google created a great language for the average developer, referring to Go.
@BennyDaon10 ай бұрын
Go is great and you're right - a language is more than a tool. Great languages come with coding patterns and a PoV and you have to embrace it or your code will suck.
@harrisoncramer8 ай бұрын
One of the benefits of Go is also that it's easier to make open source projects. People who do not know the language can easily understand it and even sometimes submit fixes or PRs.
@akshay-kumar-00711 ай бұрын
Tom loves Go for a reason
@WiecejNoxiego10 ай бұрын
Few things that would make Go beautiful in my opinion: - tagged unions - operator overloading (had to work with big.math for past 2months and I hate it) - syntax for error bubbling (no if err != nil) I think it's unlikely that I'll be getting any of the features above, but that would really be lovely. I don't need anything else from the language, but even rn go is good enough that I use it despite lacking things described.
@sandeepvk9 ай бұрын
This is so true. When I came from JS to python and saw no semicolons I hated python. I still do but I have learned to love python. I think I key is to learn to love and focus on the problem not the tool
@brumd2111 ай бұрын
The thing I miss the MOST about Rust when moving to any other language is Rust's enums combined with match. Legendary features.
@razvangrigore32211 ай бұрын
Even PHP has that now.
@ursochurrasqueira10 ай бұрын
dart has it too
@stoffni10 ай бұрын
@@razvangrigore322 PHP.. no joke, is actually quite nice now.
@gokulakrishnanr841410 ай бұрын
Agreed! Rust's enums and match features are top-notch. 👍
@usopenplayer11 ай бұрын
You can prove that language complexity matters by taking it to extremes. Some of the simplest languages are lambda calculus and combinators languages. I think one of the simplest languages possible is "Subleq". It has only a single instruction: "SUBtract and branch if Less-than or EQual to zero". Fully Turing Complete in one instruction. What could be simpler? On the other extreme, we could have a dedicated syntax for every single unique operation, which would require an every increasing vocabulary, though every program could be a single symbol in such a language. What could be simpler? Obviously neither of these extremes are desirable, but we need to find a happy medium.
@duke60511 ай бұрын
Why I don't use golang in 2024: my company loves paying hundreds of thousands of dollars in server cost a month because "PHP devs are cheaper"
@baxiry.11 ай бұрын
hhhhh
@koalakakes11 ай бұрын
im not sure php really raises server costs all that much as much as i dont like php.
@duke60511 ай бұрын
@@koalakakes it does. It does A LOT. Rewrote a service in go. Went from $6k a month to
@gokulakrishnanr841410 ай бұрын
Sorry to hear that 😔. Have you considered exploring alternative options for cost-effective server solutions?
@ichbinhier35516 күн бұрын
@@koalakakes it does as long as you are not using a cheap hosting provider (which most people do for their wordpress site, which is the reason php is so popular)
@nguyentanphat775411 ай бұрын
For functional paradigm, Elixir is undoubtedly the choice, looking forward to your Elixir series xd
@AJewFR011 ай бұрын
Elixir is cool. I spent all of december and january using it 10-20hrs / week. i’m sold it’s the solution for small teams. Phoenix is Rails but better.
@creativecraving11 ай бұрын
Undoubtedly the best? Have you compared it to Lisp, Clojure, Haskell, Ocaml and Rust? I haven't tried Elixir yet, so I can't make a comparison myself.
@harrybarden543811 ай бұрын
Elixir doesn’t have types, which are a must have for most people
@creativecraving11 ай бұрын
@@harrybarden5438 So everything's a string? No arrays, no numbers, no hash tables?
@tapasdatta622210 ай бұрын
Yeah Elixir is the best lang.
@logannance1011 ай бұрын
I switched to Go last week and it's nice to see you're doing the same
@matteo.veraldi10 ай бұрын
What do you use to parse .templ files in NeoVim? I use coc-go for .go files but I didn't find anything for templ
@awesomedavid201211 ай бұрын
I recently created a basic benchmark to compare Odin and C. Yes, I know how hard it is to make meaningful benchmarks, but I wanted a rough idea. (this is relevant to the video btw) I made a singly linked list, started with 6 elements and added up to 1000 one at a time. Each time it added an element, it did a basic linear search to find the end and add the new node there. I then deallocate the whole list. I ran this 1000 times and averaged out the time it took. I found Odin took about 2.4ms per run. Unoptomized C took about 7ms, and then compiling with -01 or higher landed C at 0.5ms roughly. I'm still not sure exactly why the time discrepancy, but they are pretty close. I then wrote the exact same code in Go to see how close C and Odin really are in performance. I expected a garbage collected language like Go to be a lot slower than either manual memory management implementation. The average time for Go was about 5 microseconds, or about 100x faster than C. Either Go is optimizing away the whole process, or my best guess is that the garbage collector actually makes it more effective. Now, both my C and Odin code is very naive. I simply call malloc/new every single time I create a node. I'm guessing Go is able to create larger allocations and split them almost instantly per each node. At least, it's my guess that malloc is the bottleneck. I can't imagine why linear search would be any faster in Go. Is this to say Go is faster than C? No. Because the code isn't the same. I could create a better allocation strategy in C and get better performance than Go. But I think this is a very important idea. Yes, if you write the correct code, C is faster than Go. But with equivalent code with equivalent work put in (actually, Go was a lot easier to write than C), Go can be a lot faster. I assumed even a naive approach in C would have to be faster than any garbage collected language. It's manual memory management, how can it be slow? But a naive approach in C is much slower than a naive approach in Go. And this is a major part of the value of Go. Not only is Go much faster and enjoyable to write than a language like C, it's simply easier to write performant code. You don't have to study allocation strategies and optimize for your specific problem. The language will likely do a decent job and get you 90% of the way there for most things.
@awesomedavid201211 ай бұрын
In before my Go program was actually cheating and not performing the same thing. I also ran the benchmark in Python btw. At first it took 3 hours (cause I had an infinite loop) but then it took 17 minutes total, with something like 106ms per run. Classic python. Edit: I also ran go using "go run" rather than building since that should in theory keep it in debug mode and not risk optimizing things away. It was 5x slower but still way faster than C.
@HammytheSammy-ds2em11 ай бұрын
Welcome to the club, Gopher! Go is amazing for CLIs, backends, data transforms, and even the PyTorch lib is bearable for Go. It is a wonderful language for what it’s built to do. Some people even code games in Go which I’d like to try since there’s libs for a few engines.
@Ataraxia_Atom11 ай бұрын
Looking forward to learning go with boot dev
@gcasanas18 ай бұрын
Set your calendar notification for two years review.
@gljames2411 ай бұрын
I felt the same about snake case. I thought it was weird at first coming from Java, but it's so much more readable! Not as convinced about the parenthesis tho.
@fahimzahir958711 ай бұрын
I miss your old hair Prime. It looks nice but very distracting for my caveman brain. I just tune out everything and focus on the hair.
@ThePrimeTimeagen11 ай бұрын
Haha, This is what happens when you lose a bet, it'll be gone soon
@ma3452911 ай бұрын
PrimeDaddy has announced his Gopher status, now let's see how popularity in their subreddits change over the next 6-12 months. As of today, Feb 15th, 2024: Golang => 238,000 subscribers Rust => 274,000 subscribers
@aakarshan464411 ай бұрын
Go got that dawg in him
@PeterBernardin10 ай бұрын
I was waiting for you to come around to Go! I'm a nerd like you and like powerful languages with all the bells and whistles. But when it comes down to real life, Go is simply more practical for most cases. It forces you to do things one way that's simple, stripping away what you don't really need. Go isn't perfect by any means. But for most projects, when you take ALL factors into consideration (including for example speed of development and readability), generally speaking Go will come out on top and the obvious choice. The fact that it's garbage collected also doesn't seem to have that much of an impact on performance for general use cases. It still performs in the same league as other low level statically typed languages.
@gxtoast22214 ай бұрын
Maybe algebraic data types are best in domains that require sophisticated data semantics, and a simpler type system is good for a more performance focused domain that has less semantic complexity?
@MuradShahsuvarov10 ай бұрын
Go is the king🏆 Hope it keeps get updated and get better and better💫
@sunnypelletier389611 ай бұрын
I just wish go would add a short way to handle null pointers. Something like `variable?.property`. I don't believe this goes against any of go's principles of simplicity, but it does make the language much faster to write and easier to read when you have a lot of possibly nulls to handle.
@deluxe_133711 ай бұрын
His hair is blue because he loves Go so much
@brinckau11 ай бұрын
green, not blue.
@koalakakes11 ай бұрын
I've started using Go for most things as a security engineer. I mostly build microservices like AWS Lambdas to solve security problems which i think lends very well to the simplicity of Go. You already have a 'simple/micro' problem to solve and then take a language that succeeds in that simplicity and it is just beautiful.
@keymatch-clovis11 ай бұрын
I was once doing an app in Laravel with Svelte, and I didn't know how to set up Svelte with TypeScript. I love TS because of the type system, the hate against JS, and bla, bla, bla. So I said -Well, fk it, I'm going to rawdog JS for a while. Some time later, I managed to compile TS with Svelte, and I was happy; I would be able to use my beloved type system again! But... but then I realized that the modules and the logic that I had done with JS was much more simple, good and, overall, easier to understand. In TS I was worrying too much about generics, types, interfaces, trying to make traits, mixins (search that one out and tell me I'm not dumb). I think about that now... maybe I want a simpler language, with simpler tools to just get the job done, and not lose myself with all of that funcional, OOP jargon and stuff. Love you prime btw ❤
@75hilmar5 ай бұрын
Sounds like a pretty reasonable premise
@charlesdarwin435110 ай бұрын
I have been using Go at work for few years and I am trying to become proficient with Rust. I like to learn new things and Rust ticks that box perfectly. Which one I like best? I love them both.
@sigfaults10 ай бұрын
Go isn't my favourite language at all but it's honestly so easy to be productive in and the tooling is great so I'm finding myself enjoying it more and more!
@stylishskater9210 ай бұрын
Back in 2012~ i was a PHP developer and at my job tthere was a coworker who used C/C++ style parentheses for class and function declarations and if/loop statements, meaning even the leading parentheses are always on a new line. It was such a minute and irrelevant thing but annoyed the shit out of me when i saw it, especially coming from a Java background originally. Year later i somehow love it and much prefer it to in-line leading parentheses, and now im unhappy in most modern codebases where its not done that way lol.
@DeanRTaylor11 ай бұрын
Glad to hear this, it will be interesting to hear reflections after six months.
@colinmaharaj11 ай бұрын
1:00 yeah in order for your app to be simple your code may get complex, or if you have a complex app then maybe your code is too simple
@_Khrix10 ай бұрын
I had started programing 6 years ago, with JavaScript. To me, was the GOAT language for everything. Now, typescript still the majority part of my salary, but i see Kotlin and Go as the best well design, go for, language.
@phene-44911 ай бұрын
i'm still on the rust train but i totally get what you're coming from. when i use go it feels like it's lacking features. i know that can be a positive thing but i don't like that. for prototyping or very simple apps, i do like that, but when it comes to actually building something i don't. i also enjoy the "process" of writing rust code and thinking through problems in that way.
@Luclecool12311 ай бұрын
I don't feel like I have a need to learn Go... It's some kind of in-between trade offs that I don't find appealing
@justesjc5 ай бұрын
Great advice here. Make sure you are idiomatic in the code you write, so you can learn what the strengths and weakness are for the that tech choice.
@huge_letters11 ай бұрын
hey, what's the number one type system you've seen then?
@ekeminios10 ай бұрын
Great insights shared, thank you.
@s3rit66111 ай бұрын
Why some programmers do hate Java? Why who loves Java usually hates go? I can't figure out the pattern, i'm starting to think that people get used to C-Like programming languages and hates the rest, most of the time is all about syntax and not features. 8:30 that's exactly what i'm talking about, i hate Go and JS for a syntax reason, i'm simply not used to it
@atiedebee102011 ай бұрын
Java syntax very closely resembles C. I personally hate java because it forces you to do everything object oriented which can very quickly lead to poor design
@s3rit66111 ай бұрын
@@atiedebee1020 Martin Fowler proved with design patterns that you can build object oriented with a good design and he choosed Java to explain them
@atiedebee102011 ай бұрын
@@s3rit661object oriented isn't bad / good per definition, but it very quickly leads to overcomplicating things. It's better to have a choice of paradigm be optional than forced onto you like it's done in java.
@codey139111 ай бұрын
@@s3rit661 Java is not open source, and the JVM way of running things takes so much configuration and setup compared to other languages. Trying to figure out which versions of the JDK to install is always confusing. Deep object oriented programming is incredibly annoying, and inheritance is always a mistake, leading to overcomplicated design. These are some of the reasons I've disliked working in Java over the years. There's a severe lack of simplicity in the language and its ecosystem.
@s3rit66111 ай бұрын
@@codey1391 OpenJDK enters the room
@JH-pe3ro11 ай бұрын
The downside of bouncing between popular languages - which was my first 15 years or so of programming - is that all of them are iterations on "Fortran" (to borrow Forth creator Chuck Moore's sentiments) so you don't get to spend a lot of time doing anything really wild - you get to consume a type system that's a little more or less sophisticated, and some new libraries. The stuff that isn't a Fortran, no corporation wants to hear about, and the barrier to casual usage outside of that sphere tends to be much higher as well - less documentation, example code etc. I bring up Forth in part because it's the "simple to implement" kind of simple; implement a tiny core and then bootstrap the rest and you have a Forth system - even the IF ELSE THEN statements can be metaprogrammed in a minimal Forth. Does that make it productive like Go? Not exactly. I've been using it for retrogame coding and I like debugging Forth because it has the repl interactivity you need to really drill down and craft a very exact implementation of something. But it does not "help you with that" - it's just a thin layer of glue over chunks of assembly code, and its approach to memory management is to bump the allocation pointer word, "HERE", as you declare new words. One of the first things you will do as a Forth beginner is crash it by inverting the order of source and destination in the write-to-address word "!". So in practice, I've got a setup where I have Lua generate Forth source. I can write Forth directly and push it upwards semantically by metaprogramming, or I can treat it as a dumb stack machine and implement some compiler semantics and just use it to debug. It takes me much longer to build solutions than if I were in my usual comfort zone and leveraging libraries and all of that, but as a hobby exploration of computing, I finally feel like I get to understand my spec very precisely, since ALL the magic parts have been removed. I'm throwing a great deal of engineering brainpower at some very small problems.
@kenneth_romero11 ай бұрын
i had this same issue learning rust. tried to port a calculator app but damn did the syntax fuck me over. everything felt so messy compared to when i did it in c++ or java. just a skill issue, but is something jblow also said himself. gave up on rust for now since my main goal is to get a job using c or cpp, and i think zig would be a more enjoyable and skill transferable language to learn.