Your backend is too complicated

Поделиться
HTML-код
  • Опубликовано: 19 янв 2025

Комментарии • 507

  • @IsaacHarrisHolt
    @IsaacHarrisHolt  8 месяцев назад +58

    ERRATA:
    5:19 - `task.try_await` doesn't protect you from the task crashing, only from timeouts. The correct way to avoid crashing the host process would be to use a supervisor. `try_await` will, however, return an error if the process EXITS with an exit code. If the process panics or is killed, the host process will crash.
    9:11 - Yes, yes. It's POLYNOMIAL, not exponential.

    • @tryoxiss
      @tryoxiss 4 месяца назад

      A timestamp to 9:11 in an 8:47 video?

  • @asdanjer
    @asdanjer 8 месяцев назад +718

    I love how the answer to too many programming language is always more programming languages.

    • @mAcCoLo666
      @mAcCoLo666 8 месяцев назад +29

      But we know better, don't you see!

    • @UnfiItered
      @UnfiItered 8 месяцев назад

      ​@user-fc8xw4fi5vbut c isn't inherently safe so we need a language that is safe.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +29

      Almost all the time

    • @BrianJorgensenAbides
      @BrianJorgensenAbides 8 месяцев назад +8

      I waited to see if XkCd replied directly. Munroe, we prayed for you here!

    • @yaksher
      @yaksher 8 месяцев назад +4

      how_standards_proliferate.xkcd

  • @olegdayo
    @olegdayo 8 месяцев назад +249

    How to be a fresh backend developer?
    It's simple, just:
    -Migrate from PHP/Python/Perl to Go-
    -Migrate from Go to Rust-
    Migrate from Rust to Gleam

    • @pyyrr
      @pyyrr 8 месяцев назад +37

      wonder what language is next week. all these rewrites are so productive

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +27

      The difference is that Gleam already has a mature ecosystem thanks to being built on Erlang, so you don't have to reinvent all the basic packages

    • @javierflores09
      @javierflores09 8 месяцев назад +26

      ​@@IsaacHarrisHoltthat argument also applies for kotlin, however Gleam is the new shiny thing so I guess it is cooler to try

    • @AlexanderSuraphel
      @AlexanderSuraphel 8 месяцев назад

      @@IsaacHarrisHoltare they compatible with the type system. For eg how mature are the ORMs at this point? Gleam is so interesting btw

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      You have to write FFIs to get them to work with the type system, unfortunately, but it's quite easy to do. People are writing ORMs in Gleam as it's easier to do that than to try and FFI onto something that dynamic. I'm sure it's possible though

  • @andreujuanc
    @andreujuanc 8 месяцев назад +142

    "Your backend is too complicated" -> "I'm going to skip explaining this bit because it's too complicated for this video" xD

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +21

      Point taken, but it's difficult to fit stuff in 10 mins 😂

    • @Meknassih
      @Meknassih 5 месяцев назад +9

      Exactly my thought, and even worse, he then proceeds to use a solution that wouldn't even work in production because 'Actors' cannot handle concurrency. How is that convincing anyone? 😄

    • @penguindrummaster
      @penguindrummaster 4 месяца назад +3

      ​​@@Meknassih you misunderstand the provided solution. Actors *do* handle concurrency, by design. They aren't recommended as a permanent solution here because they will act in a somewhat synchronous fashion (FIFO single-threaded evaluation). For the point of the demonstration, it is more than sufficient. For a real application that could see many thousands of requests per second, it would be worth the additional effort to grab a more performant, if less user-friendly, solution.

    • @Aporro1
      @Aporro1 4 месяца назад

      ​@Meknassih it is somewhat remedied by the effortless concurrency vid

  • @kora_lin
    @kora_lin 8 месяцев назад +121

    How many GIFs do you want to use in your video?
    Isaac: Yes

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +11

      Can't never have too many

    • @dabunnisher29
      @dabunnisher29 8 месяцев назад +5

      @@IsaacHarrisHolt Yes you can and it totally turned me off on yet another friggin language.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Fair. This video style isn't for everyone :)

    • @lawrencejob
      @lawrencejob 8 месяцев назад

      @@dabunnisher29👀

    • @theherk
      @theherk 8 месяцев назад +7

      @@dabunnisher29have you considered evaluating a language based on its merits rather than the number of gifs in a video about the language?

  • @LuisM_Santana
    @LuisM_Santana 8 месяцев назад +9

    This new toy in town seems fun, I just wanted to add a side note: if there's one thing that is becoming too complicated in the current programming world, is not the Backend precisely (I will argue the opposite) but the frontend (that has fully embraced the Javascript hell) is quite more complicated today than it was a decade ago

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +3

      You're not wrong, but Gleam can simplify that too 😉 I'll be doing a video on full stack Gleam soon

    • @LuisM_Santana
      @LuisM_Santana 8 месяцев назад +2

      @@IsaacHarrisHolt cool! Looking forward to see it, especially the deployment part

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@LuisM_Santana Ah, it'll probably just be Docker or Fly.io, to be honest. There's a good guide in the Gleam docs.

  • @Rundik
    @Rundik 8 месяцев назад +54

    "must never crash" it's not how you write reliable software. Your app must crash, but you should make it so that users don't notice it. I other words it should be able to tolerate crashes and still have close to 100% uptime

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +22

      Yes, processes should crash, but the system as a whole should ideally never go down. That's what I was aiming for :)

    • @user-93fekod1o
      @user-93fekod1o 8 месяцев назад +9

      wtf is that terrible advice, apps/apis should NEVER crash. Specially APIs. If a user crashes your API, it'll down for everyone else unless you have multiple instances deployed, and even IF you had multiple instances deployed, why would you knowingly let it crash? wtf lol

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +14

      The ethos of the BEAM is "let it crash", but that generally applies to single processes. The idea is that it's better to let a process (e.g. a task in Gleam) crash than try to recover and make a load of error handling mess

    • @user-93fekod1o
      @user-93fekod1o 8 месяцев назад +2

      @@IsaacHarrisHolt well yeah but you'd usually be using something like supervisor for important things

    • @fulconandroadcone9488
      @fulconandroadcone9488 8 месяцев назад +5

      @@user-93fekod1o you should let program crash on unexpected error because it was unexpected and it doesn't know how to handle it, unless of course you know in advance how to handle an unexpected error in which case you would not have time to write comments on youtube.

  • @ryzh6544
    @ryzh6544 8 месяцев назад +42

    It really seems to me that Gleam is the truth.
    1. High-level feel with GC
    2. Functional but simple
    3. Strongly and Statically typed
    4. Errors as values
    5. Exhaustiveness
    6. Built-in Scalability due to the Beam
    I like that

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +5

      It's quickly become one of my favourite languages!

    • @remcogreve7982
      @remcogreve7982 8 месяцев назад +4

      Only the divide by zero thing is really strange.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +4

      @@remcogreve7982 I think that's an Erlang thing. Gleam has a divide function in the standard library that'll return an `Error` if you try to divide by zero, if you want to use that

    • @remcogreve7982
      @remcogreve7982 8 месяцев назад +3

      @@IsaacHarrisHolt Returning an error is at least better than having a wrong answer quietly. That is the worst option for handling errors imaginable.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Again, I think this is an Erlang limitation. I might be wrong on that, though. I agree that it's not the ideal scenario

  • @mr.johnson8974
    @mr.johnson8974 Месяц назад

    Nothing is better than Go for backend.
    1. Everything you need is in the std library
    2. Syntax is dead simple.
    3. Concurrency is dead simple.
    4. I’ve never written cache handler longer than 50 lines of code in Go. Having the cache as a separate process (ie redis) provides a fault tolerant system.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  Месяц назад +2

      Go is great! I agree with your first three points for sure. On the last one, with the BEAM, your cache can be a separate process, or even on a separate node, but still be in your program, and still be perfectly fault tolerant!

  • @BrunoBernard-kn6vt
    @BrunoBernard-kn6vt 8 месяцев назад +55

    Just as a sidenote, the discord community for gleam is great too :)

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +5

      It is! I'm reasonably active there, and I love it

  • @md2perpe
    @md2perpe 8 месяцев назад +6

    The formula num_battles = n * (n-1) / 2 is quadratic in n, not exponential.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      You're technically right, but most people don't say "it grows quadratically" or "it grows polynomially". "Exponentially" is just the common term :)

    • @mAcCoLo666
      @mAcCoLo666 8 месяцев назад +6

      Well then it is the wrong term. How do you call something tha grows like 2^n?

    • @md2perpe
      @md2perpe 8 месяцев назад +4

      @@IsaacHarrisHolt I've never seen that incorrect use before. Could you provide examples where you have seen it?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Something "growing exponentially" is quite a common phrase even outside of maths/comp sci

    • @MadsterV
      @MadsterV 8 месяцев назад +3

      @@IsaacHarrisHolt common does not mean it supersedes the correct terms.
      Polyonimial growth is ok, exponential is not. They're very different.

  • @NH-ij8dz
    @NH-ij8dz 5 месяцев назад +4

    Having spent the past week playing around with Gleam I don't think it's very good.
    - Poor standard library (have to use Erlang for basically everything, even taking input from stdin).
    - Base data structures are bad (slow).
    - Have to compile everything to Javascript or you get Python levels of performance.
    - Being unable to return early from functions makes the language feel like ass to write once you start trying to do anything complex.
    - Pattern matching is meh. You're often nesting pattern matches inside pattern matches and it results in code that's a complete mess.
    - Documentation is terrible and unfinished.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  5 месяцев назад +2

      The first point is a fair criticism, but there's some stuff that's not included deliberately. Generally, something will only be in the stdlib if it has a consistent behaviour across Erlang and JS. Reading from stdin doesn't.
      Gleam is not designed for ultimate performance - it's designed for scalability.
      Lack of early return is normal for functional languages, but Gleam allows you to simulate early return with `use
      It's not common to have more than one or two levels of matching. Can you show me an example?
      This is a fair point - the language documentation needs work. Great opportunity for some OSS contributions😉

    • @Monkeydew1o2
      @Monkeydew1o2 2 месяца назад

      ​@IsaacHarrisHolt It must be said that performance and scalability go hand in hand.
      For example, I built an ABSURDLY optimized piece of python code. As optimized as you can get before bit magic.
      All this to taste a fraction of Go with the same degree of complexity.
      Not everyone can afford the cloud equivalent of 2 Xeons for every project.
      If python ran like go. The internet would run 90% cheaper.

  • @dandogamer
    @dandogamer 8 месяцев назад +2

    I'm glad someone is doing some videos with gleam!! Would love to see some more about the gleam OTP and concurrency. Also some simple web dev stuff like how do I connect it to a postgres db etc

  • @h-j-k-z
    @h-j-k-z Месяц назад

    the only advantage gleam has over elixir is static types. anyone that's used elixir knows it doesn't need static types. although they are working on gradual types, but you don't have to annotate them if you don't want.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  Месяц назад

      Gleam's also a lot easier to learn. While Elixir is great, it does have a steep learning curve for folks who've not touched the BEAM before. Gleam makes a lot of that easier.
      Also, Gleam compiles to JS, so you can run it in the browser for a full stack development experience without needing the compromises of something like LiveView (namely latency)

  • @BrianJorgensenAbides
    @BrianJorgensenAbides 8 месяцев назад +18

    How did you not mention OTP in this entire rant (which I loved and agreed with). Does your stack have agents? Oh wait Gleam is the answer to all of this. I approve. Just snarky about people seeming to not realize, "we've been solving this since the 60's"

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +3

      Very good point! And yeah, I've been getting deeper and deeper into Erlang-land recently watching conference talk videos. It's really fascinating to me

  • @ArthurKhazbs
    @ArthurKhazbs 8 месяцев назад +3

    Reminds me of Kotlin, but somehow without the async coloring. Something between Kotlin and Go, maybe.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      I've never done Kotlin, but I keep hearing good things about it!

  • @rallokkcaz
    @rallokkcaz 8 месяцев назад +2

    Yes I really wanna see more about the concurrency APIs in Gleam, I haven't seen much.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      On it!

    • @rallokkcaz
      @rallokkcaz 8 месяцев назад

      @@IsaacHarrisHolt Thank you! I'm excited to try out Gleam to do similar tasks I've used Elixir for! I remember when Gleam first started, the project has changed alot in the past 2 years. Interesting to see the JS focus as well, almost sort of a strange choice of effort? Still not sold on that.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      It makes sense, as it allows you to share types and things across the backend and frontend

  • @Skeiln
    @Skeiln 8 месяцев назад +6

    I use and work daily with C#, even for API stuff, and so far everything I used it for just work fine as expecting
    Its not always the fault of the language but also the programmer implementing it, good working code can be written in most good languages without issues
    Even on my job we use C# day in day out, software engineer here, we also use other languages but my section is purely based on C#

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      Totally fair! C# can be a good language for that sort of thing, but you still have to reach for external services or micro services to achieve a lot of the things you can achieve in BEAM languages like Gleam.
      And you're right, you can write good code in any language. That said, some languages make it easier than others to maintain a high standard.

  • @anar-k-jafarov
    @anar-k-jafarov 6 месяцев назад +1

    Elixir does the same and in most cases looks the same.
    But sometimes it gets annoying when You write pattern matching and think about fancy handling.
    So annoying that want to return to Ruby, PHP, NodeJS unfortunately.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад +1

      I'm curious what you find annoying about pattern matching?

    • @anar-k-jafarov
      @anar-k-jafarov 6 месяцев назад +1

      @@IsaacHarrisHolt repetitive patterns, most of times copy pasty

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      You'll get that with anything though, I think

    • @anar-k-jafarov
      @anar-k-jafarov 6 месяцев назад

      @@IsaacHarrisHolt that's question of taste - who loves patterns who loves try catches, who loves Option, Result types, somebody goes unwrap.
      I'm Elixir I solved it by writing result handling function overloading and piping.
      Not everyone is pattern matching lover.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      That's fair, but my point is you'll always get repetitive code

  • @aronjacobson5403
    @aronjacobson5403 8 месяцев назад +3

    I still don't get the `use` syntax. I've tried to understand it through the documentation and more but I just can't get to understand what it does and when it works. It said something about returning the value of the function that was a parameter or something like that and I really don't get how to use it. It seems like a great feature but I just can't wrap my head around it.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +5

      Basically it just avoids some nesting. So instead of:
      ```
      result.try(my_result, fn(ok_value) { logic() })
      ```
      I can do
      ```
      use ok_value

    • @aronjacobson5403
      @aronjacobson5403 8 месяцев назад

      @@IsaacHarrisHolt Thanks for the clarification I think I'm getting the gist of it now! Seems pretty useful for sure.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      @@aronjacobson5403 It's great for achieving sort-of-early-returns using `bool.lazy_guard`

  • @its.arjun.s
    @its.arjun.s 5 месяцев назад

    Man, Erlang is underrated. BEAM has gotta be one of the most impressive things I've seen

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  5 месяцев назад

      It's honestly incredible. It's a shame it's not more popular

  • @flareflo362
    @flareflo362 8 месяцев назад +5

    >damn time to rewrite it all in rust
    mfw gleam is written in rust
    Carcinisation keeps winning

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Hahaha yeah there's definitely some irony there, and it might even have been deliberate 😉

  • @NathanielBabalola
    @NathanielBabalola 5 месяцев назад +1

    What's the performance of gleam compared to other Backend langs and framework please

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  5 месяцев назад

      It's not a performance oriented language, so it's the same as the languages it compiles to. In this case, JS and Erlang

    • @NathanielBabalola
      @NathanielBabalola 5 месяцев назад

      @@IsaacHarrisHolt thank you very much, so I would like to clarify if it's selling point is just concurrency ?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  5 месяцев назад

      That's not the only selling point. Gleam runs on the Erlang BEAM VM, so yes, it does have great concurrency, but it's also incredibly fault tolerant, type safe, and a joy to write. It also has great error handling and a really nice community :)

  • @funkdefied1
    @funkdefied1 8 месяцев назад +3

    Does it have pattern matching comparable to Rust’s? (Object destructuring and exhaustive enum pattern matching)

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +3

      It does! Have a look at my Gleam for Impatient Devs video for more of an overview

  • @kokop1107
    @kokop1107 8 месяцев назад

    Love the sponsor, really cool idea. Seems more useful for experienced programmers than those leetcode style platforms.

  • @marcusrehn6915
    @marcusrehn6915 8 месяцев назад +1

    Gleam really feels like the parts of Scala that I actually liked

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Interesting! Which parts would those be?

    • @marcusrehn6915
      @marcusrehn6915 8 месяцев назад

      @@IsaacHarrisHolt Honestly, I think its mostly just the pattern matching, fp in a c-like syntax and the immutable data structures.
      What I don't like about it is that you can write it just like Java or just like Haskell or an unholy mix of the two. I also seems to add any feature dreamed up by any PHD student into the standard language.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@marcusrehn6915 Yeah I think that's a lot of what Gleam is trying to solve. Every feature is really thoroughly thought out before it gets added

  • @pjderouen
    @pjderouen 8 месяцев назад +3

    Bro how was the algorithm thinking ahead of me

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      It's almost like that's why it was made 😉

  • @stass191
    @stass191 8 месяцев назад +1

    my hype dropped to the bottom when I learned that gleam doesnt have loops and forces you to use recursion instead

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      That's very common for functional programming languages. Most of the time you can just use the stdlib functions like fold, reduce etc.

  • @opposite342
    @opposite342 8 месяцев назад +2

    I have one question, is the play_button / triangle ligature in your font this: "|>" ?
    edited: I read the code, it seems like it is... I was confused how to make that for a moment haha

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +3

      It is! Just the standard pipe. I'm just a big fan of ligatures

    • @opposite342
      @opposite342 8 месяцев назад +1

      @@IsaacHarrisHolt Yep I've realized that it is, thanks for confirming.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      No worries!

  • @siestoelemento1019
    @siestoelemento1019 8 месяцев назад +3

    gleam can make a rest api, but cannot make a community though

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      What makes you say that? I'm quite active in the community and I love it

  • @colorfulfool
    @colorfulfool 4 месяца назад

    @IsaacHarrisHolt Sorry if that's been answered elsewhere, couldn't find, what's the color scheme and font you use in this video?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  4 месяца назад

      It's AstroNvim with JetBrains Mono. That said, don't just copy me :)

    • @colorfulfool
      @colorfulfool 4 месяца назад

      @@IsaacHarrisHolt Well, I'm already using JetBrains Mono, no wonder it looked familiar, so halfway there :)

  •  8 месяцев назад +5

    I honestly don’t really get why i should switch from Go to Gleam? What are the benefits? I could get how the BEAM is more explicit with errors and more fault tolerant than e.g. goroutines
    But I’ve also heard that gleam is far less performant?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +5

      You're not wrong! Gleam is less performant than Go as it's not a compiled language. However, as you said, error handling and fault tolerance are better, and it's MUCH easier to create distributed systems with the BEAM.
      On top of that, Gleam's type system is much better than Go's. You don't need to worry about nil pointers, nil structs etc., and you get proper sum types rather than the error-prone kinda-enums you get in Go.
      Plus, there will, at some point, be a native target for Gleam, which will improve performance (though you'd lose the BEAM).

    •  8 месяцев назад

      @@IsaacHarrisHolt Oh man, guess I have to learn another new language now :D I think I was put off by Javascript being a compilation target, but I guess I can just ignore that and do stuff with Erlang.
      I can't seem to find a lot of benchmarks out there, so do you know what an average performance delta there is?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      I don't, but Gleam isn't really built for performance (like many BEAM langs), so I imagine it's pretty large.

    •  8 месяцев назад +1

      @@IsaacHarrisHolt fair enough :D thanks for creating this awesome gleam content though!

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      No worries!

  • @pretro6136
    @pretro6136 8 месяцев назад +10

    just reminding, just as every tool has it's advantages, its disadvantages are equally as big

  • @tobeqz7065
    @tobeqz7065 8 месяцев назад +1

    Interesting, this seems like rust except without the rough edges and running on BEAM. Ill be sure to give it a try

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Please do! Let me know what you come up with

  • @laughingvampire7555
    @laughingvampire7555 6 месяцев назад +1

    just use Erlang, yes I know this run on BEAM and that is why I'm saying it, just use Erlang.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      By using Gleam you are kinda using Erlang, but you get the benefits of a fantastic type system too.

  • @Nick.....
    @Nick..... 6 месяцев назад +1

    I honestly just like Gleam for the little star guy logo

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      Her name is Lucy and she loves strawberry ice cream :)

  • @pesiok
    @pesiok 6 месяцев назад

    Looks interesting, I've been following Gleam development for some time now. I'm bound to try it out at some point.
    For the time being though it looks like a watered down and less mature version of Scala.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      Interesting take, for sure. Have a go and let me know what you think :)

  • @over_clockwise
    @over_clockwise 8 месяцев назад +1

    Anyone know what font and color theme is being used in the text editor at around 1:30 ?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      It's Neovim with JetBrains Mono, AstroNvim and astrodark

    • @phatboislym
      @phatboislym 7 месяцев назад

      @isaacharrisholt man of culture

  • @broccoli-dev
    @broccoli-dev 8 месяцев назад +11

    I'll stick with Elixir.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +4

      Any particular reason? You can use Elixir libraries from Gleam, and you get the added benefits of the type system too.

    • @D4no00
      @D4no00 8 месяцев назад +3

      @@IsaacHarrisHolt gleam threw a lot of great stuff from erlang to the trash in favor of an imperative programming style, absolutely not a fan of that.
      Not having macros and/or reflection is a deal breaker to me, I tend to write nowadays a lot of declarative code that uses these feature under the hood to process the declarations. As for the types, the only rule is to validate external data, use typespecs and static tools like dialyzer to get almost the same precision in your codebase, having the added benefit to use fully dynamic values where you don't need a precise data shape.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Totally fair. You can still use all the great Erlang stuff via FFI, by the way. Things like tasks and actors just call down into Erlang under the hood

    • @D4no00
      @D4no00 8 месяцев назад

      @@IsaacHarrisHolt In real-world applications this kind of complexity is not a reality. We use elixir in production because it is extremely good in terms of readability, extensibility and core libraries. Portions that need types to be checked can be covered by libraries like NimbleOptions (BTW the feature level this library has is what a good type system should look like). If elixir manages to create the static type checker, languages like gleam will be not be of much relevance in the future.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +3

      I think we can agree to disagree on this one. Also, Gleam isn't imperative. It's still a very Functional language.

  • @blouse_man
    @blouse_man 8 месяцев назад

    that video had alot to unpack, too much for my brain, that's complex, grug brain can't get all of it, 50% was over my head, time to re watch this, keep this good work up

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      It might help to go through it slowly with the code in front of you. It's in the description :)

    • @blouse_man
      @blouse_man 8 месяцев назад +1

      @@IsaacHarrisHolt will be waiting for the gleam concurrency video

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Working on it!

  • @siestalol
    @siestalol 8 месяцев назад +11

    exactly what I need right now?? great video!

  • @pixsa
    @pixsa 10 дней назад

    OK, Do a performance benchmark then !

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  10 дней назад

      Comparing what? At what scale? Between which languages? What are we measuring and why is that important? What are we measuring?
      It's never as simple as just "do a performance benchmark".

  • @JMCV2
    @JMCV2 22 дня назад

    No mention of Elixir ?

  • @smthngsmthngsmthngdarkside
    @smthngsmthngsmthngdarkside 3 месяца назад

    Very Simple :tm:
    > Insert Mind Cloud of Unknown Depths

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  3 месяца назад

      Gleam is very simple! You can learn the whole thing in an afternoon 👀

  • @tkblackbelt2
    @tkblackbelt2 8 месяцев назад +1

    Why not use elixir?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      You could, but Gleam's type system makes it easier to have large-scale projects, and makes refactoring a lot easier.
      Plus, you can use all your Elixir libs!

  • @MatthewRobinson-k7k
    @MatthewRobinson-k7k 6 месяцев назад

    Who is actually using Gleam in production that's notable?
    How does Gleam handle unstructured data?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад +1

      There are a few startups being built in Gleam, and a few Gleamlins have managed to get it into prod at their companies. I couldn't tell you who, though.
      As for unstructured data, Gleam handles it like any other strongly typed language - you have to try and decode it into a Gleam type to work with it. There's _technically_ a Dynamic type, but you can't interact with Dynamic values except to decode them or just pass them around, so if you don't need to know the shape of the data at any point at all, you can just use that

  • @ZisulinMorbrot
    @ZisulinMorbrot 8 месяцев назад +1

    What's the font and the color scheme used here? It looks exquisit and I need it.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      It's JetBrains Mono and I use AstroNvim with the astrodark colour scheme.

    • @ZisulinMorbrot
      @ZisulinMorbrot 8 месяцев назад

      @@IsaacHarrisHolt Thanks so much!

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      You're welcome!

  • @parkourbee
    @parkourbee 4 месяца назад +2

    Gleam seems cool, but I think I'll keep using Rust.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  4 месяца назад

      They're for totally different things

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  4 месяца назад

      Update! I released a video today explaining why this comparison doesn't make sense: ruclips.net/video/uvQL-xJWGwI/видео.html

  • @lpil
    @lpil 8 месяцев назад +12

    Heck yeah, Gleam!

  • @plebeianpatrician7860
    @plebeianpatrician7860 2 месяца назад +1

    This is too complicated, I'll just do it in C.

  • @jvstbecause
    @jvstbecause 8 месяцев назад +4

    And why can't I just use another programming language? Rust with axum looks similar

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      You can use what you like! Gleam is just simpler to get started with, and Rust is famously difficult to make parallel.

    • @jvstbecause
      @jvstbecause 8 месяцев назад +1

      @@IsaacHarrisHolt Ok, thanks for the answer :)

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@jvstbecause of course! I'm happy to help

    • @1vader
      @1vader 8 месяцев назад +2

      Rust is famously difficult to make parallel??? How easy it is to parallelize complex code without introducing race conditions and stuff like that is one of it's main selling points. And with rayon, its extremely nice and easy to parallelize simple stuff. Rust certainly is not the easiest language to learn but in no world is it "famously difficult to make parallel".

    • @jvstbecause
      @jvstbecause 8 месяцев назад

      ​@@1vader I would say writing concurrent rust code, is having the extreme benefits as well as problems of Rust. It is very hard to start but easier to master as other programming languages. Stuff like performance optimized async traits, tower services and the general Sync + Send + 'static requirement aren't easy to get right at the start. There are other languages that get you going faster, for example Go, where you can just write `go function()` to make something "parallel". Of course, rust has this concurrency model because of good reasons, but knowing them is a must to understand and work with them. In conclusion, I would say Rust can be easy for experienced users, but they are a headache for beginners and I wouldn't recommend them this approach at the begin of their rust journey.

  • @collinpearce310
    @collinpearce310 8 месяцев назад

    9:13 The number of battles does not increase exponentially, they increase quadratically (yes, pedantic, but I this is a comp sci video)

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Totally fair! I mostly used 'exponentially' because it's the common term, but I'm aware it's not technically accurate

  • @yahi06
    @yahi06 8 месяцев назад +1

    my answers for the intro was elixir... but cool they bought run on Erlang

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      The BEAM VM is awesome, and Elixir is also a great language. I just like my types 😅

  • @AshesWake-sf7uw
    @AshesWake-sf7uw 18 дней назад

    How does gleam, make you not use a cache store nd a message queue 😅
    Huh

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  18 дней назад

      I demonstrated the cache in the video, and as for the message queue, concurrency in Gleam is often handled using actors, which have a mailbox that acts as a queue, processing a single message at a time! It's quite easy to build systems on top of that to replicate fanout queues and so on too.
      In fact, RabbitMQ, one of the most popular messages brokers, is built on the same virtual machine Gleam uses!

  • @awesomedavid2012
    @awesomedavid2012 8 месяцев назад +1

    I tried Gleam by making the usual higher-lower game but I got stuck and couldn't find in any docs how to read from stdin so I left and haven't gone back. Seems like a nice language. I'm sure I just skill issued myself hard.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      The BEAM doesn't have the best story for CLI applications, honestly. That's unfortunately a limitation of the platform, given it's not what it was designed for. I'd suggest trying out a web server or some other project :)

    • @bpo217
      @bpo217 8 месяцев назад +1

      Wrong domain! I don't think it's a con either. For compiled languages I'd say the closest functional feel language is OCaml and the closest simplicity feel language is Go for CLI software.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      @@bpo217 yeah, Gleam feels a lot like a functional Go to me

    • @bpo217
      @bpo217 8 месяцев назад +1

      @@IsaacHarrisHolt Indeed. I like the project you decided to go with btw 👍🏻

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@bpo217 Thanks!

  • @mihaip1179
    @mihaip1179 8 месяцев назад

    Like the difference betwen Salsa on 1 and Salsa on 2 is almost impercetible to the music deaf, what makes backend so different from front end?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Very little! You can write full-stack apps in Gleam using the Lustre framework

  • @bity-bite
    @bity-bite 8 месяцев назад +4

    I don't understand the point of this video when I can do all of the mentioned stuff in C# and faster, too. Although Gleam does sound interesting worth as a side project for exploring it

    • @idkanymoreman
      @idkanymoreman 8 месяцев назад

      Exactly what I was thinking too

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      I'm not familiar enough with .NET, but I do prefer writing Gleam to C#. Give it a go and let me know what you find :)

  • @nanashi2622
    @nanashi2622 8 месяцев назад +2

    I'm stubborn, so I'm still gonna write my APIs in Rust.

  • @NeatMemesDotCom
    @NeatMemesDotCom 5 месяцев назад

    The Never ending Shoehorning of Tech World.

  • @livinlicious
    @livinlicious Месяц назад

    We have 20 concurrent languages. This is stupid. We should create one that fixes all these issues as a one stop solution.
    Now we have 21 concurrent languages.
    This is this video.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  Месяц назад

      Gleam isn't a new concurrency system, it builds on Erlang!

  • @nickmartin7418
    @nickmartin7418 8 месяцев назад

    Doesn't C# have a similar Task based API with the TPL and can handle concurrency...

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Very possibly! I don't know C# well enough to comment, but the BEAM VM is hailed for concurrency and how easy it is to create distributed programs

  • @IlyaFadin
    @IlyaFadin 8 месяцев назад +1

    why don't you like Scala?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      I don't dislike it! I've just never used it.

    • @IlyaFadin
      @IlyaFadin 8 месяцев назад +2

      @@IsaacHarrisHolt it has everything - safe types, immutability, parallelism, make your own types with wild flexibility and much more!

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      I'll take a look some day :)

  • @lawrencejob
    @lawrencejob 8 месяцев назад +1

    Gleam is great but I prefer the syntax of Roc

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Totally fair! Not everyone likes the more C-style syntax

    • @lawrencejob
      @lawrencejob 8 месяцев назад

      @@IsaacHarrisHolt Incidentally I'm likely to use Gleam at work whereas I don't think Roc will ever be finished! Roc is made by one of the creators of Elm, which also inspired Gleam.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@lawrencejob Yes! I watched one of the Roc talks. It looks interesting. And do let us know if you use Gleam at work! The community would love to know what you do with it :)

  • @ケブ
    @ケブ Месяц назад

    Assembly all the way 🎉

  • @fantasypvp
    @fantasypvp 2 месяца назад

    0:31 you assume that rust wouldn't be my first choice for writing a backend to begin with 🤣

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  2 месяца назад

      Yes, because it probably shouldn't be (see my video on Gleam and Rust for why!)

  • @garretmh
    @garretmh 8 месяцев назад +4

    I enjoy using fonts with ligatures but I think it’s a bad fit for informational videos

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      That's a fair take! I'll probably disable them in future if I remember

  • @jsonkody
    @jsonkody 2 месяца назад

    0:01 I would choose Elixir 🎉

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  2 месяца назад +1

      Good choice! Elixir gives you a lot of the same benefits as Gleam, just without the type safety :)

  • @thefastjojo
    @thefastjojo 7 месяцев назад

    What font are you using? :eyes:

  • @AderionsVids
    @AderionsVids 8 месяцев назад +3

    Great video! As a rust dev not convinced of gleam though. Feels like this is almost easier to implement with actix.
    Plus not having to deal with the erlang VM also sounds like a great advantage to me.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Fair points. For me, I prefer not having to deal with the borrow checker, move semantics, lifetimes, and Rust async etc.. Gleam makes it much easier to deal with concurrency

  • @user-93fekod1o
    @user-93fekod1o 8 месяцев назад +2

    That was pretty good

  • @pmrebel2733
    @pmrebel2733 7 месяцев назад +1

    Not again!

  • @_theone_99
    @_theone_99 8 месяцев назад +2

    I don't understand, in what language is the equivalent code for this going to 'blow up in your face'? If the only difference is the Option type, I don't think thats a really convincing argument to switch, or even try to learn an entirely new language just for that

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      Any language that uses exceptions makes control flow practically invisible. You have to have some global try/catch block in your code. Gleam allows you to handle errors where they crop up

    • @_theone_99
      @_theone_99 8 месяцев назад

      @@IsaacHarrisHolt agree with you on that. However that just makes me like go even more, it returns error as a value, and as a dev you have to make the conscious decision of ignoring an error

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@_theone_99 that's no different to Gleam or Rust, in reality. The benefit of Gleam over Go is that you have proper sum types and don't have to worry about nil, and therefore nil pointer exceptions

    • @_theone_99
      @_theone_99 8 месяцев назад

      @IsaacHarrisHolt yep, weird decision from the creators to not have an option type. I am hopeful about sum types though, hopefully they introduce it soon.

  • @i-am-the-slime
    @i-am-the-slime 5 месяцев назад

    Why not PureScript?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  5 месяцев назад

      Gleam also gives you the Erlang target :)

  • @TheHTMLCode
    @TheHTMLCode 8 месяцев назад +2

    Still trying to decide if I want to pick up Zig or Gleam…they’re both very compelling

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +2

      I know the feeling! I wanna learn more about both databases and distributed systems, and it seems like Zig would be better for one, and Gleam the other 😅

    • @TheHTMLCode
      @TheHTMLCode 8 месяцев назад +1

      @@IsaacHarrisHolt that's the exact dilemma I'm having. No doubt I'll find time to dabble in both, but I'd love to master something other than Go! I do love Gleams erlang roots though...agh decisions decisions!

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Try them both for a while and see how far you get!

  • @SnowDaemon
    @SnowDaemon 8 месяцев назад +4

    great examples and great logic.
    love this.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Thanks! I'm glad you found it useful

  • @raphaelprinz9944
    @raphaelprinz9944 7 месяцев назад

    Gleam reminds me so much of F#.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  7 месяцев назад

      But with less Microsoft

    • @raphaelprinz9944
      @raphaelprinz9944 7 месяцев назад +1

      @@IsaacHarrisHolt True, but F# deserves more love, really nice Syntax and Features with friendly Community.

  • @RazorSh4rk
    @RazorSh4rk 5 месяцев назад +1

    nah i can do it in go

  • @bjornericcom
    @bjornericcom 6 месяцев назад

    Been wanting to check out Gleam more, so happy I found this channel, thanks! :)

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      Awesome! Let me know how you find it :)

  • @han_gh_2708
    @han_gh_2708 Месяц назад

    me learing gleam bc it is a cute pink star

  • @ChuckAsum
    @ChuckAsum 7 месяцев назад

    Dotnet sticky cache monolith

  • @kiplimoboor
    @kiplimoboor 8 месяцев назад

    Can you share your nvim config?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      It's pretty much just the default AstroNvim config :)

  • @harrybilsonia
    @harrybilsonia 8 месяцев назад +1

    golang not mentioned? i wonder why...

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Go did get a mention! Right at the start. I just didn't draw many comparisons because in some ways, Go is very similar. It's also one of my favourite languages, but I like Gleam for having proper sum types and no nulls :)

    • @harrybilsonia
      @harrybilsonia 8 месяцев назад +1

      @@IsaacHarrisHolt okay, that's fair, my bad

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      No worries at all!

  • @okie9025
    @okie9025 8 месяцев назад +12

    And then there's me, thinking about solving your initial problem in Java Spring Boot in 20 minutes with no need for Redis or any other external service, perfectly fine error handling, exceptional stability, and clean, non-verbose code. People really overlook the "boring" languages in favor of the hottest language of the week which is more often than not made more for computers and less for humans (cough cough Rust).

    • @cuca_dev
      @cuca_dev 8 месяцев назад +5

      Yeah, when I watch videos like this I wonder if some people ever had to deliver software to production. So much cognitive load for simple things.

    • @NekoApril
      @NekoApril 8 месяцев назад

      ​@@cuca_devA big idea within ML inspired languages is that the simple things should be hard to make the complicated things easy. For an example of how this works you could watch Tsoding's video on making a JSON parser from scratch in Haskell.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +4

      I agree that Rust is probably a lot harder than it needs to be, but I disagree with you on Java's error handling. I'd much prefer errors as values to throwing exceptions.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +4

      @cuca_dev really? Writing one program is more cognitive load than deploying 10 microservices, RabbitMQ, Redis, and managing all of that? I'd prefer a single program, personally.

    • @ANONAAAAAAAAA
      @ANONAAAAAAAAA 8 месяцев назад +6

      I think this current trend of favoring and shilling "the hottest languages" is not good for fresh juniors who's entering this industry.
      There are a lot more important and basic stuffs backend devs need to know before playing with Rust, Gleam or Elixir.
      I rather want juniors understand the things like SQL, POSIX commands, HTTP protocol, networking stuffs and how to write tests.

  • @CernyMatej
    @CernyMatej 2 месяца назад

    Just use Scala

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  2 месяца назад +2

      Scala looks cool! I've not had the chance to use it much though

    • @CernyMatej
      @CernyMatej 2 месяца назад

      @@IsaacHarrisHolt Look at Scala 3, the new braceless (python-ish) syntax is so elegant!

  • @adriancruz2822
    @adriancruz2822 8 месяцев назад +3

    Great video. I dunno why people in the comment section in this video are being so smug and obnoxious but you are taking it like a champ!

    • @ParanoicoBR
      @ParanoicoBR 8 месяцев назад +1

      Some people take it personally when you say there is an alternative to their favorite language

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Thanks! I appreciate the positivity :)

  • @thesynalice
    @thesynalice 8 месяцев назад +7

    Even Rust still doesn't have proper ecosystem. How much time would it take for Gleam to mature, huh?
    And the selling points aren't there either. Awesome concurrency exists in Go and Elixir. Why would I want Gleam? I want to get things done, not be a pioneer of yet another language.
    Meh.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +6

      Gleam can use Elixir and Erlang libraries, so you get the benefit of those mature ecosystems already, so no worries there.
      As for why you'd use Gleam over Go, it's mostly for the type system and the BEAM. I'm a massive proponent of Go, don't get me wrong, and I love writing it. But, Gleam's type system is a lot more robust. There are no nil pointers exceptions or gotchas like that, and Gleam has proper sum types.
      Give it a try and you'll see :)

    • @mellowcloud6434
      @mellowcloud6434 8 месяцев назад

      Gleam compiles directly to JavaScript/Erlang. It has pretty much zero overhead over erlang so it's faster than elixir
      It also has FFI compatibility with elixir and Erlang if compiling to erlang and has FFI compatibility with JavaScript if compiling to JavaScript.
      There have been what feels like a million libraries to release since launch, rarely I need to do FFI but when I do it's fast syntax

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@mellowcloud6434 this is absolutely right. It compiles to Erlang which is then executed right on the VM. As to whether it's faster than Elixir, I've not done the tests. It's possible that Elixir produces more optimised bytecode at the end of the process than the Erlang that Gleam creates. It would be interesting to test.

    • @junaid1464
      @junaid1464 6 месяцев назад

      @@mellowcloud6434 it can't be faster than elixir, both runs on same VM, are your sure it compiles down to erlang? usually beam languages put out beam binaries aka .beam file. if it does, then compilation should be slow.

    • @junaid1464
      @junaid1464 6 месяцев назад

      I have been writing elixir for last four years, I like dynamic languages without too many type intervention, it's definitely a good to have when it comes to types. But elixir's community is so mature that everyone is nice enough to reply and write documented code. over the years I have noticed one thing with languages, the more easy you make a language to get started with, the more shit code that community generates. Look at Go, I have read so many codebases of Go, everything just abuses channels, just because compiles and works people be like okay, I'm right, not really care about quality.

  • @davidmurphy563
    @davidmurphy563 Месяц назад

    The type safety myth... I'd love to know who these people are who need to stop themselves assigning a string to the variable `number`.
    Do you know what happens to python programmers who don't use type hinting? Nothing. Because mixing up types is either a sign of gross incompetence or, far more likely, the monster lurking in the child's cupboard. You know, there one that isn't there.
    If you're doing it for performance - that's perfectly valid, all power to you. If you're doing it as a crutch because you think you need your hand held - you almost certainly don't. Take those stabilisers off and just ride your bike like an adult.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  Месяц назад

      This is definitely one of the comments of all time.
      You come across as though you've never worked on a large project with many developers. When writing software in teams, the best thing you can do is get the computer to do as much of the work for you as possible (auto formatting, lint checks, automated testing, etc.). Type checking is part of that - it reduces the mental load on each engineer, increasing the development velocity of the team as a whole.
      If you're relying on variable names to tell you their types, e.g. "number", you're basically introducing your own weak, inconsistent version of static typing anyway and creating more work for the people writing code and the people reviewing code.
      There are cases where dynamic typing is helpful, for sure, but for the work that 90% of people are doing, having static types is going to be a boon purely for the time it saves debugging issues.
      As much as anything else, static typing is a form of documentation. When you're onboarding new engineers onto a project, having types for them to read makes parsing the codebase infinitely easier - they don't have to keep all the context of all the types of every possible permutation of variables in their head to understand the flow of what's going on. And if you try to make the argument for documenting types in docstrings etc., again, you're using a poor-man's static typing.
      On the Python point, as someone who has written a fair bit of Python professionally, and used to make Python videos on this very RUclips channel, a lot of the industry is moving towards using type hints as much as possible. The same trend can be seen in other popular dynamically typed languages - Elixir is getting a type checker built into the compiler, and Ruby's Sorbet is growing in adoption.
      Basically, all this to say... what??

    • @davidmurphy563
      @davidmurphy563 Месяц назад

      I see. You're a proponent of the bloat approach. You're in a team so pile on the boilerplate and layer on the comments.
      "We can't take the stabilisers off the bike dad, it'll fall over."
      Let's agree to differ on that front.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  Месяц назад

      Type annotations aren't bloat. Having to do more typing to make your life and your colleagues' loves easier is always worth it. Typing isn't your main job as a software engineer anyway.

    • @davidmurphy563
      @davidmurphy563 Месяц назад

      @@IsaacHarrisHolt They literally are boilerplate.
      Listen, we clearly have very different ideas of what constitutes good code. You're the the verbose / explicit camp, I'm in the minimalist. Some experienced coders would agree with you and competent coders would agree with me. :)

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  Месяц назад

      @@davidmurphy563 you're very difficult to have a constructive conversation with, by god.

  • @ChiisaiNeko-jh8dn
    @ChiisaiNeko-jh8dn 8 месяцев назад

    nice vid isaac 👍

  • @framegrace1
    @framegrace1 7 месяцев назад

    When you say "other programing languages" just mean node/js.
    All others I know use threads (Or can use threads) just like gleam.
    Nice how you just discovered the "cache" trick.... Dude, that has been done on any other language with proper threads for ages, and, check that, you can do that even with DB connections it's called connection pooling. Yeah, a pool of connections for all processes, I know ... rad, just java 1995 style...
    Maan.. kids this days...

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  7 месяцев назад

      It's important to know that BEAM processes are not that same thing as threads. Most languages that allow threading will use OS threads, generally limiting you to 2x the number of cores in your machine.
      Gleam processes are closer to green threads. They're very lightweight, and you can have thousands of them per machine.
      I never claimed to have "discovered" keeping mutable state in another process. I was merely using it as an example of how powerful the BEAM is. Again, sure, you might be able to do this in other langs, but you'd have to have a mutex around your shared state.

    • @framegrace1
      @framegrace1 7 месяцев назад

      @@IsaacHarrisHolt I also think that gleam is an elegant solution to most common multithreading cases. is just that you are comparing it to node and how node works. I would not say that's "most other languages" as you imply in the video. Much as the contrary, I would say that the node approach is the exception, not the norm.
      I could implement this beam model (not as elegantly, sure), on any of the languages I know. I've used similar constructs in java, for example.
      Not sure where you got that information, but you can have many many more OS threads than cores, (on linux, the default limit is 100k, i think, and can be expanded).

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  7 месяцев назад

      I wasn't comparing just to Node. I was using it as an example, sure, but I was actually comparing to most async/await systems, which do use an event loop. Python is the same, as is Tokio for Rust. Most of them are based on libuv or libuv-adjacent tech.
      Apologies - you're right, I was getting mixed up between OS and CPU threads. Yes, you could implement a lot of this with OS threads, but again, the BEAM and its mailbox system handle things in a graceful way such that you don't have shared memory and don't have the footguns that entails.

  • @Andy_B.
    @Andy_B. 8 месяцев назад

    heard about DBOS cloud (or edge DB)?!

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Sure, but I'm not 100% sure why they're relevant here :)

  • @fuadcs22
    @fuadcs22 8 месяцев назад +2

    I don't like monolith codebases. I mean might need something to be re-written completely. What about database migration, file handling. Each language and runtime their own strength. So I'll rather use different languages and runtimes for different uses and connect all of them via pub/sub or stream.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Totally fair! My point in this video is that too many people reach for that by default. You see lots of companies running microservices when they have like, 10 users.

    • @fuadcs22
      @fuadcs22 8 месяцев назад +1

      @@IsaacHarrisHolt Yeah that's true. I love the quote, "You shouldn't think about handling 1M users at the first place. When you have 1M users. You would love to have that problem."

  • @lawrencejob
    @lawrencejob 8 месяцев назад

    Devs who hate that new languages get made are going to have a miserable career

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      I think that languages are just getting more specialised over time. Go was created for distributed systems and servers, Rust was created for memory safety at all costs, etc. There are fewer and fewer general purpose languages being made, which some people may not like, but it means the languages that pop up will be loved by the small section of devs they're aimed at

  • @yetzt
    @yetzt 8 месяцев назад

    Sounds like Erlang.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      Gleam compiles to Erlang! So yes, it's very similar. But Gleam is statically typed, which brings a whole host of benefits around error handling and so on, as you can see

  • @AdityaSingh-uv8uf
    @AdityaSingh-uv8uf 6 месяцев назад +1

    gleam propaganda before gta6

  • @uchennaofoma4624
    @uchennaofoma4624 8 месяцев назад

    Is that astronvim I see 👀

  • @gigachad8810
    @gigachad8810 8 месяцев назад +2

    wait how is this in any way better than rust?

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      It's different, honestly. Sure, the performance probably won't match Rust's, but Gleam makes it very easy to parallelise (something that Rust is famously not). You also don't have to fight the borrow checker at every turn, and the type system (which is what most people love about Rust) in Gleam is based on Rust's, so you'll feel comfortable moving.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад +1

      I think they're aimed at different things. Gleam is definitely more beginner friendly, but the performance ceiling is lower

    • @vladlu6362
      @vladlu6362 8 месяцев назад

      ​@@IsaacHarrisHoltRust's motto is literally "fearless concurrency". It's really really easy in rust.

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      @@vladlu6362 It's fearless, but that doesn't make it easy. It just means that you don't need to worry about race conditions etc.

  • @Shr-Coding
    @Shr-Coding 7 месяцев назад

    00:22 idk, my answer is still python :V

  • @aberges
    @aberges 5 месяцев назад

    you go so fast :P

  • @abdelazizabdelioua890
    @abdelazizabdelioua890 6 месяцев назад

    Just use pocketbase as framework

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  6 месяцев назад

      Pocketbase solves DB and auth, but not more complicated things like message queues, caching, etc. Gleam can solve all of these without third party dependencies. You'd still want a database, though.

    • @abdelazizabdelioua890
      @abdelazizabdelioua890 6 месяцев назад

      @@IsaacHarrisHolt ok I see what you mean

  • @kristun216
    @kristun216 8 месяцев назад +1

    Elixir

    • @IsaacHarrisHolt
      @IsaacHarrisHolt  8 месяцев назад

      Why not Gleam 👀

    • @kristun216
      @kristun216 8 месяцев назад

      @@IsaacHarrisHolt to be fair, I haven't personally tried Gleam. not sure if it looks different enough for me to bother trying. types are nice but i haven't encountered a massive issue with Elixir being dynamic so far