Comparing 10 programming languages. I built the same app in all of them.

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

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

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

    "It is a skill issue but an issue nonetheless."

    • @sebastianpaulis7184
      @sebastianpaulis7184 7 месяцев назад +13

      I died when I heard him say it

    • @angeldude101
      @angeldude101 7 месяцев назад +85

      Hearing "skill issue" and it being treated like a real issue rather than an excuse to ignore a problem felt oddly refreshing.

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

      So, dont blame the language with skill issues! Learn it properly.

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

      "It's an issue that doesn't exist in other languages" was also funny.
      But on a serious note, it doesn't exist in other languages only because those other languages don't care about proper error handling.
      In cases like Rust or Gleam what he was doing with the "let if" and "match" syntax did work, and it was proper error handling. There's no skill issue. The skill issue only appears because the language provides a more "idiomatic" or less verbose way that you haven't learned yet.
      The extra idiomatic feature just raises the skill ceiling, without actually taking away from the more verbose syntax. So it's still hard to call it a skill issue. Other languages would be happy with just a single try...catch around the entry point saying "nice, handled error 🥴"

    • @samisiddiqui5286
      @samisiddiqui5286 4 месяца назад +5

      In case of Rust, skill Issue is really serious issue. It gets harder and harder to comprehend as the project grows

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

    Timestamps for folks:
    1:00 Golang
    3:25 Crystal
    5:47 Kotlin
    7:33 Swift
    9:28 Zig
    11:38 Gleam
    14:07 Nim
    15:30 Dart
    16:50 Julia
    18:01 Rust

    • @AttrakoNull
      @AttrakoNull 7 месяцев назад +4

      elixir?

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

      @@AttrakoNull Bro needed static types.

    • @IOnGust
      @IOnGust 3 месяца назад +1

      Vlang

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

    As zig is pre-1.0, it moves very quickly and the LSP targets the nightly version so it probably didn't work for 0.11. Once it hits 1.0, the idea is to not change the language much and things will settle down a bit. Sorry you had a bad experience with Zig. It really is a great language. If you ever try again, use the nightly!

    • @tom-delalande
      @tom-delalande  8 месяцев назад +106

      Thanks for the mention. If the tooling does work on nightly that's my mistake. I will definitely try it again, there's so much to like about it.

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

      that’s not true, the lsp has tagged builds for each release, including 0.11. As it is the lsp doesn’t work anywhere that comptime is involved, which is pretty much everything

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

      I like zig, but I find the standard library to be lacking and its documentation is an insult. The vast majority of functions and flags are completely undocumented and many are not obvious (what is std.macho about ?), there are very few examples of usage. There are no functional programming primitives (map/reduce, not talking about filter, fold, zip, etc as there are no closures in zig), and no regex. This is a bit annoying.

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

      ​@@InXLsisDeo But strangely enough, it has cryptographic primitives. Not something I expected to find in the std of such young language, but good for me I guess since I needed those.

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

      @@InXLsisDeodude, we’re on 0.1, what did you expect?

  • @sp.n7401
    @sp.n7401 8 месяцев назад +120

    Nim starts getting good when you look into metaprogramming. See some of the DSL libraries like Jester or HappyX. Also its ability to compile into C, C++, or JS makes it good for pretty much any domain.
    Also note Nim's memory management model nowadays isnt really a traditional GC, but the memory is automatically managed at compiletime.

    • @tom-delalande
      @tom-delalande  8 месяцев назад +43

      It seems like need to put some more dedicated time into Nim. Thanks for the advice

    • @yuitachibana8829
      @yuitachibana8829 6 месяцев назад +12

      Imo nim has the same problem with modern c++, too many ways to do 1 thing and unopinionated so each project has a completely different structure

    • @sp.n7401
      @sp.n7401 6 месяцев назад

      @@yuitachibana8829 I think the standard library is very consistent with one way to do something. Where C++ feels like you have to read a book on every individual subsection, Nim is pretty straightforward and you can read anything that only uses std.
      That's what makes me appreciate Nim more and want to distance myself from C++. Plus, macros still use Nim's standard calling conventions so it never feels jarring.

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

    I use Nim at work for exactly a kind of use-case it excels in: Fast native-compiled statically-linked data processing that needs to be portable to embedded platforms (my giant program compiles as-is on ARM using musl-libc), with ergonomic Pythonic syntax that ensures you don’t need to worry about memory issues. It can be best described as either: Very fast native-compiled Python, or extremely, unrecognizably ergonomic C++. Take your pick.

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

      Did you learn it just by reading the docs?

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

      Damn

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

      @@eduardabramovich1216 There's a free book by Stefan Salewski. There's also NimDays which is a collection of mini programs made in Nim, and also How I Start which is implementation of Brainf*ck interpreter in Nim. Also the creator of the language has recently released his own book.

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

    Gleam mentioned!!!

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

      Great language! Thank you so much man

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

      Beyond cringe 😂 just learn Rust or Go

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

      @@ccriztoff RUST MENTIONED! LETS GO

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

      @@jamlie977 Rusty and Crabpilled

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

      I know this guy

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

    can't wait to see this when zig is at 1.0+ like the other languages on the list.

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

    Nim also supports checked exceptions btw. And the default GC is refcounting like swift.

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

    Thanks for taking the time to do all this coding and evaluation. It's very nice to see the implementation in diff. languages. IMHO, Rust code is the most unreadable, by far.

    • @YT.Nikolay
      @YT.Nikolay 7 месяцев назад +1

      ChatGPT can convert the given code to any language that existed before 2019 ;)

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

      @@YT.Nikolay not really? when trying to get chatgpt to convert to more obscure languages (like D for example) it makes a lot of mistakes.

    • @YT.Nikolay
      @YT.Nikolay 6 месяцев назад

      @@thezipcreator not entirely perfect, but for majority of cases, it did work for me

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

    Julia and Nim, such wonderful but underrated languages. Both in my top 3!

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

      What is your other top 3?

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

      @@patrickmoehrke4982 ok, don't freak out. It's R, I am a researcher. And R do the job really well.

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

      @@blaisepascal3905 Haha I also use R! It doesn't get enough credit outside statistics and academia.

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

      @@blaisepascal3905 same, I've been working in R for the last few years and it's wonderful for stats and plotting, but I was able to get some really complex genetic epidemiological modelling done with Julia pre-2020 which R would have choked on. Two languages that seem to scare people off, but are so nice to use once you get the hang of them.

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

      Yeah he basically ignored all the real use cases for Julia which makes it seem like a glorified bash. But try doing complicated math in bash and you'll quickly see where Julia excels.

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

    You do an excellent job. All that was left to do was take into account the quantity and maturity of the library ecosystem.

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

    Very agreeable takes, thanks for your efforts!

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

    I don't really understand why Dart got such a low score. It feels like it gets a lot of things right, and I had a blast using it to maintain a production Flutter app. It feels like your grades don't align with your feedback :D

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

      Dart got a high score and came in fourth.

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

      he actually didn't use the nice parts of Dart. the `..` operator is pure genius for initialisation, making dependency injection work without any clunky library or "bag of globals". the automatic parameters make robust initialisators look like magic. like with Zig, it requires more than just a glance to appreciate. I bet he had previous experience with some of the most highly rated ones, which helped him find the best parts of those.

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

      I use dart since 5 years and I love it, I think he treated dart fairly. There is still stuff we want and don't have yet in dart. Static metaprograming (it is coming very soon), error as value not exception (no plan to change this at all, so you have to import fp library like fpdart and use either type). For some reason they don't want to let us configure line length on a per project basis, and default line length is 80... I find the pattern matching syntax to be a bit confusing (particularly when using switch expression) but it might be me I don't know.
      Except that, the toolings is just awesome. I use flutter (so dart) at work because I in charge of the mobile team, but I have to work with python for backend, I feel so miserable when I have to use python, the tooling is horrible, the language is horrible, nothing works, it is probably the worst language I ever used.

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

      @@JavierGuerra_g It is the second time someone mentioned the '..' operator as an exceptional feature of dart and I don't get it, if you embrace immutability you cannot use this operator 99 percent of the time when initialising a class, or I am missing something. Could you also elaborate how it helps for Dependency injection please? Always eager to learn new stuff about this language I love, even if I would feel dumb having missed incredible feature usage for so long

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

      @@gaxkiller there's so much to be said about how DI is great when you don't use a library and so disastrous when you do. and for most languages, the syntax gets in the way, making complex initialisations either complex and hard to read, or a whole API in itself. to make that last option somewhat more palatable, somebody invented "fluent APIs" which are nice, but tedious to implement, and create other limitations.
      in flutter, the '..' operator gives all the benefits of fluent without having to create all those initialiser methods, and thus you get those multi-line, deeply nested, but nicely-indented and very readable initialisation stanzas, where you can do all the DI you wish.

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

    Great video! I would like to see a follow-up video analyzing Elixir, F#, Haskell, PureScript, Clojure, and OCaml.

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

    Well, a 20+ minutes vidéo I actually watched from beginning to end, no fast forward, no need to rewind.
    That's become so f'in rare these days!
    Clear sections of the video where you setup your goal, testing protocol, evaluation criterias.
    Then doing it with examplification, biased opinions and objective comments both for each.
    Then a summary and an acknowlegement of your biases and a humble recommandation of which to choose in your opinion depending on your preferences.
    Rust only got an 18/20, but you get a 20/20 note as far as I'm concerned!
    *DING* Subscribed

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

    Zig fan here. The reason why you struggled so much with Zig might be this language's innate low-levelness. Sometimes writing Zig feels like writing LLVM IR, and for an untrained hand this is almost a chore. Tho it gets easier over time. Also comptime comptime comptime. It is incredible, and i get immeasurable high when it works the way i want. You can pretty much have every single feature of any language, have it as a zero-runtime, and have it not being a macro. This is nothing but witchery, atleast it feels like it.

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

      He didn't struggle as much with Rust though.

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

      @@AGAU1022 i dont think Rust is nearly as low level as Zig.

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

      ​@@AGAU1022 Zig is pre 1.0, it is clearly not stable for now. Things move fast. People are bound to face issues but still many are adopting it. While Rust has been around for a while now. The creator of zig was frustrated to write his program in C++/Rust/C so he started creating zig. So can't really complain about a premature language

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

      i find it odd that he had a hard time with zig, but no problem with rust.

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

      @@androth1502 so true lol, Rust group bias I guess

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

    I like Dart the most! It has such clean and logical language features, it just feels nice to write! It doesn't have stupid pitfalls and shortcommings. Also, since it has a big Company behind it, it evolvs very rapidly and gets good improvenents regularly! Since version 3 it got big improvements on the functional side, with pattern matching and exhaustive switch statements. And it has null safety since version 2.

    • @olafschluter706
      @olafschluter706 7 месяцев назад +4

      The problem with dart is tooling. You can write a dart executable, but you cannot write a library with C ABI linkage (in fact you cannot write a library and ship it in binary form at all). Another drawback is that it is by nature a programming language for single-threaded applications. It has async/await, but running multiple threads using the dart standard features is awful.
      It's biggest plus in my eyes: when you come from Java, Dart is a weekend job to learn. It's a less verbose version of Java with Null-Safety and free-standing functions and variables.
      It does a pretty good job to support the Flutter Frontend Framework, where multi-threading isn't needed that much, but asynchronous operations are all over the place.

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

      @@olafschluter706 Yes, that you cannot bind C libraries easily is a big problem that just did not get enough attention, also because it works in Flutter and Flutter was the primary focus for a long time. But the team behind Dart is actively working on a solution, it is called native assets and it is behind a experimental flag at the moment.
      Of course, that it does not support multi threading easily is a drawback. Though, the use of isolates encourages the use of message passing to pass data, which is often thought to be a safer method to handle data, than for example a shared state. But I do use Dart very often and I rarely find myself actually spawning additional isolates, because for the use cases Dart is designed for, it is often just not needed. Partly because async/await works so well. Of course for use cases like Webservers it would be beneficial to implement multithreading and I think a well designed Framework could very well work around Darts limitations. And comparing to other languages, it is not worse than for example Node.js (it works essentially the same), which is one of the primary Webserver runtimes today... Only God knows why... And for example Python cannot do any real multithreading at the moment, because of the GIL...
      Overall I think Dart has great potential to replace many current solutions like Javascript (in front and backend), Python (as a scripting language, for Webservers, or even for algebraic and ML use cases), Java, C# and probably more! It is just, that the Frameworks are missing...

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

      @@olafschluter706 Dart has multi threading using isolates. And there is even a simplified implementation for flutter called compute. I find it to be very straightforward and I used to write multi threaded code in C almost a decade ago.
      As for compiling to binaries, there is a dart2native package as well as flutter being able to compile into every native platform mobile, desktop, and web.

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

      How is it different from js/node? I think they handle concurrency the same. Theyre not designed with other applications than backend for apps and apps themselves.

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

      @@adriankal Yes, Dart handles Concurrency in a very similar way than node js and is also in other ways pretty similar to node js. But I think Dart is the superior language feature, safety and experience wise. It could very well be a replacement for node js. It is just that it does not have such a big ecosystem like node js does, yet. This is where the community has to step in. The only reason why every one hopped on the train when node js came around is that you could use the same language that you use in the browser, in your backend too. But Dart can offer this too! It's just that there is currently no great priority for that by the Dart team. Flutter is it's main selling point at the time. But non the less it gets improved independently all the time with WASM support coming up next!
      "They are not designed with other applications than backend for apps and apps themselves." I don't get that part.

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

    My job literally involves Java 8 and JavaScript... I got called out so hard
    Sike! We use more and more Rust now because of me >:D

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

      lol I would be so happy to have a job writing Rust

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

      could be worse, my job is mostly Matlab/Simulink code generation. But I am also introducing more tooling in rust so at least thats nice

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

      @@owndampu1731 I despise matlab, although someone in the research lab who I work with has to write Fortran lol.

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

      C89 and some pre-C89 and Java 8

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

      Damn sucks that you downgraded!!

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

    I would have added performance as a criteria.

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

      Yeah, I love this video but for many of these languages the big benefit that he missed is their performance, and for some like Gleam performance is one of the biggest downsides. It seems like a bit of a waste to build something as good as Gleam in a way that limits performance so much.
      I guess he left it out because it didn't make a significant difference for his use case, but should at least be mentioned as a known benefit or downside.

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

      That can be misleading tho. 1-5 scale comparison in terms of tooling makes sense but comparing a runtime optimized compiled language with something like javascript may yield 500x difference in performance which doesn't make sense.
      I would keep things to compare for paradign support, tooling stuff.

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

    Pretty sure idiomatic Kotlin error handling is much closer to Rust then Java. You would use Result type to return error as value and throw for panic. I dont really know tho, I am in the process of learning Kotlin. Overall Kotlin seems like an extremely pragmatic yet expressive language, with a module system to avoid common oop pitfalls. With the mutliplatform enetring stability, it just might be a killer app of Kotlin ecosystem.

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

      The MAJOR issue with Kotlin is exactly that there is no idiomatic error handling. The official Result Type was only added after years, and they threw out checked exceptions without giving us a good, standard library alternative.
      Meaning, everyone did their own thing. You also lack convenience of a "try-catch"-like structure for Result types, meaning you end up having to manually check every Result.

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

      @@MarcelRiegler Right, it's a shame. If would much prefer an idiomatic way like Rust. But at least Kotlin has enough features like Sealed Classes and Trailing Lambdas, to easily implement a rust-like error handling. It's not perfect, but still much better than dealing with exceptions.

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

      I have tried Kotlin for Advent of Code, AoC is an excellent way to have a good taste of a language and how it would fare in real work. I found Kotlin was a pleasant experience. Its library is comprehensive and very well done.

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

    Nice comparison! Good job. Try also OCaml next time:) I'm sure you will enjoy it as it's like a rust with GC.

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

    Bro went from "I don't like errors as values is like a chore" to "I would much prefer errors as values"

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

    Nim is way, way, waaaaaaaayyyyy faster than Python, so of course there is an advantage. Regarding Nim's identity, I've heard people saying that and I don't understand the point. What's python's identity? Everything, it's used for everything. Web, desktop, data analysis, data engineering, scientific dev, scripting, sec tools... But nobody complains about that.

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

      Tbf these days I think Nim's identity is "the hacking language"

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

      And that's why I don't like either

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

      Well, taking python as a reference speaks a lot, if you eat s**t everyday, dirt might taste good to you

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

      Yeah but that’s great, because you can learn one language and do anything you want. It may not be fast but being able to do anything is quite convenient

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

      Python has such a massive following that it has packages with thousands or millions of active users in basically every sector possible. That’s very different than nim not having a niche

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

    It's kind of sad that Dart's sound null safety wasn't even mentioned. Also, Dart 3 has a much more modern syntax than Dart 2 with pattern matching, destructring etc...

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

    I'm confused. You are saying that safety is important for you, things like exhaustive switch statements, immutability, and null-safety. And then you give Go and Kotlin the same score 3. Even though Kotlin has many of the safety features mentioned while Go doesn't.

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

      same, he said he dislikes Go's error handling but said gleam had it really good, it's almost as verbose as Go's way

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

      The man explains why - he dislikes try catch and prefers errors as values. He is lazy and will ignore exceptions while writing code without the compiler complaining. Go enforces error handling, and Kotlin uses unchecked exceptions.

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

      @@TJackson736 the toInt method for strings in kotlin may throw an exception yet he praised it even though it doesn't tell you that it's may throw an exception since it uses java.lang.Integer.parseInt under the hood, it's really weird how he hates unchecked exceptions but not always

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

      it would be much more difficult to compare if allowing dependencies, he might like the result type from ArrowKt

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

      Go is simply better though

  • @maruseron
    @maruseron 3 месяца назад +7

    saying kotlin inherited unchecked exceptions from java feels weird when java is the only mainstream language with checked exceptions and kotlin specifically chose not to include them because "muh annoying"

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

    I love Julia, it's my favourite language now (apart from maybe R or Scheme). I find it elegant and aesthetically pleasing. That said, I primarily do mathematical modelling and statistics, rather than making apps, so I don't really know what it's like from that perspective. The 1-based indexing is something you'll find in a lot of programming languages popular among mathematicians (see also Fortran, R, Matlab, GNU Octave, Maple, Mathematica, and Maxima), I guess we just prefer it that way.

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

      As a mathematician, I don't. And I always prefer to index my sequences from 0. Whenever I read a text that features a sequence with index starting at 1 I have a harder time grasping proofs. Good thing about programming in mathematics is that languages tend to be functional, so you don't often try to directly access some index or do index arithmetic. Also, Python has 0-based indexing so that's cool for me.

    • @spacelem
      @spacelem 7 месяцев назад +2

      @@renato360a every time I see Python's "range" function, and know you have to say "1 to n+1" to get "1 to n" (instead of 1:n like any 1-based language) it makes me irrationally angry. Especially when numpy's "arange" function has the exact same behaviour for non-integer sequences, which makes it so much more difficult to specify the end point. I don't like Python.

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

      @@spacelem yes, I would expect that! 😅But that's a very rare case as I see it. 99% of the time I'm not specifying the starting point, so I'm just reading "range(n)" as "give me _n_ terms of a sequence", which if we start from zero, naturally should end at _n-1_ . For non integer sequences I tend to use "linspace" more anyway, which does include the endpoint.

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

      @@renato360a I'm a mathematical modeller, dealing with epidemiological and genetic models. I frequently need to simulate from t=[0..T] (end points included), but also when doing intervals it might be X(t) for t=[t1.. t2], and the next interval I need X(t2) as the initial conditions (this is absolutely the case with my current project, which involves a virus spreading between chickens, which one group being added to the previous group for a period, then moved back, and being the source of infection for the next group).
      When doing sensitivity analysis on parameters I often need linspace or logspace (or their language equivalents). It's much easier to drop the final point if I don't need it than to try to guess a value past the end that doesn't get me too many points.
      When it comes to accessing data (so integer values for an index), I just like the 1st point to be x[1], and the Nth point to be x[N], not x[0] and x[N-1]. It's less to have to think about. I know there are times when 0-indexing has helped with certain algorithms in C++ dealing with n-dim arrays, but R or Julia usually already provide the tools to not need to think about it.

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

      @@spacelem Hm. I guess it's more like to which camp does one belong to, Naturals start from 0 or from 1. Mathematicians don't make up our minds about it so you see models starting sequences from either. And you and I are from different camps...
      Personally I love subtracting 0 (does nothing) and hate subtracting 1 (shifts everything), so I'd much rather start at zero and end at N-1. A long time ago I had to get it through my head at great pains that when you subtract two integers, the result has to be increased by 1 to yield the total number of elements including the endpoints. That made it very natural for me to see a sequence to N-1 as having N elements.

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

    I picked up Dart for Flutter in its beta days and stuck with it because it just felt really nice to write. I could mostly just do as you said: imagine what I want the code to do, write it, then move on with my life.

  • @Andrey_Hz
    @Andrey_Hz 7 месяцев назад +2

    I’ve working with Bun and I am really liking it. The tooling is awesome and not require external dependencies do to the basics. The websocket module is awesome and easy to use

  • @opposite342
    @opposite342 7 месяцев назад +4

    "Nim is the least opinionated language" - I agree. Been using it for a bit.
    On the surface it's a statically typed python with even more stuffs like metaprogramming capabilities etc etc. I like the freedom but I also appreciate what other languages have to offer in this list.

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

    the biggest issue is that there are way too many languages and instead of fixing the established languages we keep adding new ones.

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

    Very interesting video. Just an idea for next similar ones: you should also compare these with "classical" languages that everyone has to use at everyday work such as Java, JavaScript, Python or C#... This would give the insight about the language evolution from the classics to the modern ones.
    Btw. I am a Kotlin fan. As I do not mind using JetBrains tooling (which is perfect!) I would give it much more points in tooling category which would make it almost a winner. :)
    I was surprised by Gleam, I have never heard of it... but I will definitely find out more.

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

      Java, JavaScript and Python some of the worst shit 😂

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

      @@ccriztoff Yes, I understand why he didn't even loose time trying them >

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

    I'd love to see you review Clojure the same way, and if you do, I'm looking forward to a shockingly low "tooling" score

  • @agathisthegreat
    @agathisthegreat 6 месяцев назад +2

    For what it's worth, kotlin has runCatching in the standard library, which effectively gives you either successful result or exception as a value if that's what you need. So it's more a style choice in kotlin. And if can allow 3rd party libraries, there's one that allows you to get even more functional (namely Arrow)

  • @danstoian7721
    @danstoian7721 7 месяцев назад +33

    9:08 Sad truth😔I feel Swift is such a beautiful language with so much potential. And while it is open-source and Apple is doing something, it's not that widely adopted because:
    1) Still needs a good cross-platform IDE
    2) Apple Documentation is terrible
    3) It lacks APIs for so many general-purpose things

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

      Agree entirely and re 1) I was gutted when Jetbrains dropped support for it last year! Their AppCode IDE is still a better Swift exploration and coding environment than XCode.

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

      My experience with Swift is just that, it is beautiful. But I find it very unenjoyable to work with it. I keep struggling with compiler errors that feel unnecessary. Even Rust is less patronizing than Swift.
      It also feels like it's a dead end as a general purpose language. It's tied to and controlled by Apple. Given the choice between Rust and Swift, if both were free, I would choose Swift. Given that there is Zig, I go for Swift, even if it's not quite comparable to Rust and Swift.

    • @twenty-fifth420
      @twenty-fifth420 Месяц назад +1

      Swift is good on Linux and while I agree the documentation is terrible, I would mostly say it is because of the features that caused me friction (C FFI, Packages, and Concurrency)
      Although a tiny thing is, Swift does have some things that most languages do not have.
      Steadiness. I dont see Swift blowing up like either Zig and Rust. I see it more like Java or C#. It is ‘get things done’ language.
      Also to the person above, I think the compiler messages for Swift are fine, but yeah, some errors are definitely loaded and kind of rhetorical.
      Surprised it got the bronze medal though. Swift is definitely a language that grows on me the more I use it. But…I really just wish apple would show me how to do FFI with C man. Nim, D and even Zig have better examples of how to use with C. Swift? Basically, Apple gives you the finger and tells you are on your own, go make a modulemap or package.swift, or something.
      Also minor pet peeve since you mentioned 3. Is it just me, or is just the API usage that trips people up? Not just for me and the standard library, but it just seems like how the documentation is generated, much of the code is kind explained with doc strings and most of the time, the actual usage and code implementation is kind of just abstracted away. That is my big issues. It took me a while to find out Swift has pointers, it is just hidden away in the Standard Library API. It basically shows you the what, but rarely how, the why or even the when. (When do i use this function or that function for pointer deferencing?)

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

      @@twenty-fifth420 Couldn't agree more. Although I could well live with the few quirks Swift has, considering how well balanced the advantages and disadvantages are. But the fact that Swift is an Apple product and the consequences make it irrelevant. It's a bit like C#. There was a time when it could have been a great choice and it actually is a decent choice in some circumstances today. But being subject to the whims of MS made it unfit for me and many others.
      I would love to see Zig thrive as a low level language and see a new high level language use Zig as a backend. I dislike Rust because its scope is too wide. It's not a great low level language and its not a high level language.

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

    11:17 on the top, there is the compile command, below is in what module the error occured, below again is the error, basically, in zig, you can only access active field of unions, there are also tagged union which you can use switch on them. here you try to access "Pointer" while the union field "Struct" was active. what you can do is check if the field is active: if (taggedUnion == .Field) { . . . } or use a switch statement: switch (taggedUnion) { . . . }

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

      The thing is that if you look closely, the message says that error occurred inside "Allocator.zig", which is part of Zig standard library. I think that message is not full, and there was more info cut below.

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

      I think I've seen a similar error in my practice. He probably tried to allocate a wrong thing and error was confusing.

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

    I appreciate you being clear and upfront about how you'll be ranking the languages. Also, you might enjoy Roc! Although TCP server might be too low-level (in Roc those things are usually handled by platfroms), so I would recommend making something else with it

  • @wolfgangschneider3743
    @wolfgangschneider3743 4 месяца назад +1

    Dart has exhaustive switch expressions (even for types), you can enforce immutability via the final modifier, it has sound null safety... In my view it's definitely safer than you made it look

  • @astromec6303
    @astromec6303 6 месяцев назад +3

    I think modern c++ (c++23) also deserves a mention. It’s come a long way even from c++17. It has features like optional and expected and other features similar to other modern languages in that list (although they are not strictly speaking enforced due to it still allowing for the old style). Although I must admit that the syntax is still ugly af in some cases and it can get extremely difficult to read very quickly even for basic tasks. It’s also extremely verbose but it’s still fast with zero cost abstraction and tries to modernize (good attempt imo) and became much safer.

  • @ShivaniSharma-h7g
    @ShivaniSharma-h7g 23 дня назад

    I am a beginner and recently joined coding classes at moonpreneur. This comparison video is going to help me a lot choosing the right programming language for myself.

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

    “There are no strings in zig, everything is an array of u8s”
    Welcome to the real world my friend

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

    You might(or might not) like D or Odin

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

      Thank you for the recommendation

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

      @@tom-delalande yeah. Np

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

    Im forever a Julia boi. I just love it. It is absolutely perfect. But maybe that’s because I’m a physicist. But it’s just a breeze.

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

      Indeed, the fact that you are a scientist may be a bias... but, Julia is just amazing like you said!

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

      As a physicist as well as a software engineer, I entirely agree. Julia just has the best syntax.

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

      @@SystemAlchemist begin and end are two words that don't do it for me personally.

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

    Love ur refreshing take. Very solid video. Thank u very much. I enjoyed this very much. U helped cut thru the type and showed me the warts of zig nim etc

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

    Gleam needs more packages and then I will use it all the time. But it's new so that should happen as more start to use it.

  • @falklumo
    @falklumo 6 месяцев назад +3

    Java has Checked Exceptions and Kotlin deliberately moved them to Unchecked for a reason. Maybe you read about why. ALso, Jetbrains IDE is the best tooling there is and Kotlin support is superb. I would rank Kotlin first for tooling and safety.

  • @abeldemoz
    @abeldemoz 3 месяца назад +1

    I was a huge advocate of Swift and had such high hopes for it. However, I've given up on Swift as a general purpose language because Apple isn't investing enough in the tooling

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

    From a ten foot view, all these 10 programming languages are the same.

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

    Swift’s sourcekit lsp works with dependencies after you build the whole project, because it does not have a background indexing unfortunately
    I use it daily with neovim, it’s still not perfect (for example renaming does not work and you have to rebuild the project sometimes for it to be able to use dependencies) but it’s good and definitely better than using an Xcode
    If you have any issues with setting it up with vim, I’ll be happy to help

    • @tom-delalande
      @tom-delalande  8 месяцев назад +3

      Thanks for the help, I did rebuild the whole project. I think something went wrong with my tool-chain where the one used in the CLI was different to the one used by the LSP. I reinstalled Xcode from scratch and the whole toolchain. But I still couldn't get it working. I think this issue was a weird combination of Sonoma + something running on Rosetta + Xcode conflicting with the toolchain. I definitely will keep trying to fix it because I want to keep using Swift

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

      @@tom-delalandeAlso a correction: Swift doesn’t have exceptions. It has errors as values. But it has syntax sugar to make it look like exceptions. It has a similar syntax sugar around it’s Maybe type by giving you a first-class nullable type.

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

      @@tom-delalandeAnd a correction for what felt like an implicit assumption: Swift does not have a garbage collector. It uses automatic reference counting by default, and you can opt into some ownership features or unsafe manual pointers for performance.

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

      TLDR; I would argue Swift has the same level of safety as Rust. This was not true for multi-threaded swift until recently. Since v5.10, there is a flag for strict concurrency checking.

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

    I think you should look into nim more. While I do agree it has some strange stolen features that don’t feel like they mesh well together. It’s actively developed and isn’t afraid to add new patterns. Honestly I would love to see you’re criticisms more in the nim community and I would love if you got involved.

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

    I came across this video in the r/gleamlang subreddit. Fantastic work : ) I think Gleam might be my new favorite non-array language.

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

    I used a lot of Zig lately so I might be bias but giving one on tooling is questionable. Setting up a project with zig build is so much cleaner than using CMake, Make, pkgconf or any other external tool bs when I have to use C or C++. Also the LSP gives a tutorial even for Sublime Text on how to set it up even though it's not the most used editor. The error messages most of time are much more readable than what you get when a C++ template code fails.

    • @lolilollolilol7773
      @lolilollolilol7773 4 месяца назад +1

      > The error messages most of time are much more readable than what you get when a C++ template code fails.
      Which doesn't say much, given those errors are hundreds or thousands of lines of mostly complete garbage, easily the worst in all the existing programming languages.

    • @happygofishing
      @happygofishing Месяц назад +1

      Zig error messages are fucking horrid.

  • @neronim0
    @neronim0 7 месяцев назад +2

    Didn't understand a word you said. Video is great tho. Am in awe of your programming capabilities ^^

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

    One thing I did not like, is how readability is being rated?
    For me, readability is the ability to read a code from someone else and know what it does. Why for example, rust with it's vast syntax is more readable than go? I don't get the justification.
    If I write code in golang, I will know what it do instantly, if I show it to anyone, they will know exactly what it does without effort. I wouldn't be so sure of that in the case of rust. Some libraries in rust is unreadable compared to others. Everyone have their own writing styles. It should be less readable than go.

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

      I was a bit confused about the readability and ergonomics ratings for Nim as well. I get that Nim is unsafe but it seems pretty readable and ergonomic and had the fewest lines of code.

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

      readability is a matter of familiarity, I don't think it can be rated since it would be unfair, for example, i write Go more than Rust and i never wrote Gleam, therefore gleam is not as readable to me compared to rust and go and rust is not as readable as go, it's unfair to rank it

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

      @jamlie977 no body said x is unreadable, but it should be a meteric of how much experience it requires. A code written by a senior go engineer will be readable for a junior dev. But rust won't.

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

      @@lazyh0rse i get you, that's why i said it's unfair for him to rank them based on readability as it's a matter of familiarity, if he doesn't have much experience with a language he would assume it's not as readable which might be false

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

      ​​​​​​@@jamlie977 It's unfair to rank it by your own subjective ability to read the language. But there is objectively readability in the sense that some languages are easier to learn when adjusting for that bias, like for beginners who have no experience in any language, and juniors with no experience in either language. A language is objectively more readable (on average when including beginners) when it more closely resembles natural language expressions of the same logic, more real words and natural grammar, less esoteric abbreviations, esoteric symbol use, and bloated non-grammatical boilerplate to declare things that should just be a default. Basically: how easily can someone without experience read it out loud in a way that accurately conveys the code.

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

    Great choice of languages. I personally would have added C# and Elixir. I would love to see a followup video with the languages people have mentioned in the comments.
    I've been a php dev for a while, so I've been looking for a new language to pick up because I'm a bit bored. I was originally attracted to rust and gleam, but they were proving to be a bit of a challenge, so I went with Go because it seems to be learnable and popular. One day though I will pick up Rust or Gleam.

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

      I was very interested in Elixir too, then I saw it is not statically typed. From personal experience, the developer experience regarding dynamic language is subpar vs statically typed language so I did not bother investing time in it. There are adding type step by step apparently but it did not solve the problem for other dynamic languages that did that.

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

      FWIW, coming from C++, golang and python, I have been using Elixir exclusively for the past couple of years, and I couldn’t be happier. Engineering productivity is through the roof.

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

    For Go you should have used scanner instead of reading the file and splitting by line

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

    "You can go back to work where you're forced to use JavaScript" hits me hard, rofl

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

    great video! It'd be interesting to compare the LOC it took in each language

    • @tom-delalande
      @tom-delalande  8 месяцев назад +16

      Thanks! Great idea.
      Here are the lines of code (including any blank lines):
      Nim - 150
      Kotlin - 163
      Julia - 170
      Swift - 180 (with dependencies)
      Crystal - 187
      Dart - 190
      Go - 264
      Gleam - 278 (with dependencies)
      Zig - 338
      Rust - 354
      Anecdotally, Go and Dart definitely felt the quickest to write and Zig took me the longest.
      Interesting that I enjoyed some of the verbose languages. I wonder if that's just Stockholm syndrome and less lines is actually just easier

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

      ​@@tom-delalande Thanks! Yeah very interesting, especially how few LOC nim took. I guess some of it could be attributed to "skill issues" :D But also more LOC could mean more resilient code because of error handling
      So yeah very cool

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

      LOC is the most useless metric. You can write s**t very quick in python, with zero error reported by your IDE and zero error handling. But then you would need 123124124 LOC of unit test to be sure that true = true

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

      ​@@tom-delalande pin 📍

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

    With your preferred features, I guess F#, Haskell and OCaml could shine here.

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

      I’d like all those way more if they weren’t GC’d. I want to try haskell just bc its haskell, but if I wanted to write something in a GC’d language I think I’d try Gleam instead

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

      I’m implying here that 1) none of these could ever be compile time gc’d like rust and 2) I think runtime, stop-the-world GC is kind of unnecessary and bad, and 3) I see little reason to adopt a GC’d language in spite of this

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

      @@mikkelens If you google "Oxidizing OCaml" you'll find some interesting work going on in OCaml moving it closer to Rust's memory ownership, borrowing etc. But I don't know any details on the status and progress.
      Regardless, all mentioned languages have modern generational & incremental GCs with very short pauses (OCaml was quite famous for its good GC on a single core). Unless you make video games or something like them, the fear of GC might be rather irrational. Gleam might enjoy Erlang's thread-local GC that doesn't stop the whole world, but it's still just interpreted bytecode, so overall performance of actual code might be much worse than in mentioned languages.

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

      @@mikkelens Haskell is a far more involved language than Gleam. If I am to compare the learning curve Haskell ranks above Rust.

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

      @@mikkelens Beam OTP gives you a nearly pauseless GC expereience. So with Gleam, Elixir or Erlang, you wouldn't really have stop the world GC problem. Hell, even JDK has a pauseless GC now called ZGC. I think the place where no-GC languagesreally outshine others is edge computing and embedded devices. Thanks to their deterministic memory management .

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

    0:25 may i suggest, C#? it has a pretty verbose code(which i personally prefer as i know exacly what is going on, and where its coming from), but aside from that i reckon it would score well in those goals.

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

    i'm most likely late af, but this error you've encountered in zig is most likely due to following things happening:
    1. you dereference a variable X, but X is not a pointer but a struct
    2. you pass a struct X as an anytype function parameter, and this function expects a pointer
    and various other reasons, but these two are the most probable ones.
    the stack traces are not always pointing at your code, that is true especially for std.fmt, but the thing is that you can 'unwrap' the full stack trace with -freference-trace arg lassed to zig build.
    hope you find it helpful.

  • @jonjimihendrix
    @jonjimihendrix 7 месяцев назад +2

    First 10 seconds had me dying laughing. Also subscribing. Love the deadpan humor.
    I’m Rust/Go as situation dictates. I love rewriting Python in Rust and running comparative benchmarks. It’s stupid how slow Python is.
    Also minor maintenance of legacy Java and C++.

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

      Mojo is the new faster Python. From the creator of LLVM and Swift, Chris Lattner.

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

      @@spht9ng no its the faster Rust written in pythonic syntax. Time for rust to pack uup the bag cuz we say not to ugly syntax

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

    Simply Rust is so good when you undestand how types work, traits, unlock full match power, iterators, you can do a lot of stuffes with just references, neither touch lifetimes or more complex memory management things

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

    hey tom I was thinking of this video and I just had the idea that if you extend those same examples trying to getting deeper into optimization for them, you would dive deeper into the languages, review what they provide for performance and so on. Lets be real that is the type of thing that everyone subscribed here would watch more than an hour easily. It would be epic, all of luck!

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

    And then there is a third group, array (and/or stack) languages, like Uiua. The most elegant solutions, assuming your inputs are integer sequences copy-pasted into the interpreter.

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

    I switched from using primarily PHP to writing most code in Rust. I made the switch about half a year ago and been using it as a first choice since then. For most of the tasks I have, Rust is more concise, quicker to write and obviously much, much quicker to execute. Often it's not by a little bit, but a massive improvement. An example I did last week was a tool for configuring a mobile device on an external carrier (I work at a small telco). The PHP code was about 1400 LoC and spread across about 40 files. In Rust this could be reduced to 450 LoC and 5 files. The rich enums are fantastic. The ability to define traits and impl-blocks for types you don't own saves massive amounts of boiler plate. The JSON parsing and encoding with serde is immensely superior to anything PHP has to offer.

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

    doesn't Intellij still offer free community edition? I'm a Rust fan first, but giving Kotlin a low rating on tooling seems wrong. Might as well nuke Gleam out of refusal to follow their styles, or Swift because you can't do actual iOS/Mac development unless you use a Mac. Kotlin tooling is top notch, if you just buy in. For free in this case, too.

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

      Sure, but you are still using **their** tooling, which has a lot of drawbacks.
      Their IDEs are very bloated, coming with lots of features you simply might not want/need in an "always on" kind of way. So a lot of that great tooling ends up feeling very mediocre to use.
      There is a reason people like their plain text editors or ones they can extend with features they actually want/need, or prefer command line tools that can have more user friendly wrappers if need be.
      Many people will simply have such a comfortable development environment set up for themselves. That might be VSCode, Emacs, Vim, etc.. So if someone isn't already on board with JetBrains IDEs, then it is quite a big ask for them to jump ship. Especially in the day and era where first class LSPs and other stand alone, editor-agnostic tooling is the norm.

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

      @@JaconSamsta Lol, I see you people using your plain text editor when I review your code and it blinks everywhere on my IDE

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

      ​@@gaxkiller
      Okay, so what's your point?
      If you are referring to things such as linters, compiler warnings, agreed upon code formatting, etc., then that is an inherently separate issue from the IDE/editor you are using.
      And if you are relying on manual code reviews to catch those things, then that very much sounds like a failure on your part. Next you are going to tell me, that you don't have an automatic test runner either.
      I'd rather not have my editor turn my office into a rave every time I type a single character into my IDE. It's an absolutely legitimate approach to fix those things, after you've gotten the code running.
      So I'll pass that "lol" right back at you, thank you very much.

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

    I had the same issue with Swift where my imports weren’t being recognized. I too have been trying to use Swift for general purpose with the Zed IDE. Crazy enough, I couldn’t find any solution or posts about this because it seems everyone using Swift sticks to Xcode.
    The solution I found that worked for me is that after specifying the dependencies in the Package.swift file, build your project using the swift package command. This forces the dependencies to be downloaded, after which, suddenly the LSP realizes your dependencies exist. Anytime you make changes to your dependencies, you need to build the project even if it fails for the LSP to actually see the changes.
    Xcode loves to do this automatically upon launching a project for the first time, this is why no one else questioned or complained about this.

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

    I wish Gleam had an option to compile into a static binary, instead of always requiring the runtime. I find myself moving more and more towards container-based deployment solutions, and while there are base images with a runtime, it bothers me to rely on heavier bases and have the runtime shipped with every container I have.
    I think that's something C# understands well, in order to have .NET 8 reliable for cloud native solutions they added the Native AOT feature, and I wish other languages relying on a runtime did the same.

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

      You should try Inko lang. It has almost Rust like syntax minus vast breadth of features. It compiles to binary as well and is mostly GC free (uses Reference counting in worst cases)

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

    I like swift, the keyword arguments in particular. But, the rust ownership model and errors as results/values are the best.

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

    11:19 in a union, only one field can be active at a time. you tried to get the `Pointer` property of the `Type` union when whatever you got the type of isn't a pointer. Since this happened at compile time, it prints out the error when compiling.
    yeah, zig error messages do need a bit of work

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

      chatGPT: "[This means that] the code attempted to access the union field Pointer, but the Struct field of the union was active at that time. In Zig, unions allow different types to share the same memory location, but only one field of the union can be active at any time. Accessing a non-active field of the union is a compile-time error.
      Fixing the Error: To fix this error, you need to ensure that the correct field of the union is accessed. You might need to check the active field before accessing it or switch to the correct field in your logic."
      I wish the compiler gave a complete error message like this one.

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

    Programming languages really are subjective.
    Most of the things you had as confusing about Crystal are super obvious to me and it's by far the easiest to understand/read language for me. Compared to Go or Kotlin which I find hard to read/follow.
    I feel like most modern languages requires an LSP to use, except for Crystal where I never use one, or really any other tooling other than syntax highlighting. Dart especially feels unwritable without an LSP.

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

    Thank you man, this was very valuable

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

    Something being a Val or var doesn’t mean it is immutable. Only that you can’t reassign it. A Val with an array assigned to it is still a mutable array.

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

    I've mostly written F# for the last few years, and I have to say I really like the look of Gleam. Will have to install it and play around some

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

    I always wondered why Kotlin seemed to be so loved and simultaneously underutilized. What a bizzare own goal by JetBrains.

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

    You can use the Result type in Swift if you prefer to handle errors as values instead of with a try catch

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

    10:38 is inherited from C so it can more easily interop with that language.

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

    19:50
    Just a quick note, because I think you borrowed that from Blow (pun intended), but I also think while it can take "10% more time to write" (even when this statement is so blank) it also can make your code "10% or more easier to write bug-free" which will save you time. So I think it is a net gain generally, but this depends on the scope and the project.

  • @kcvinu
    @kcvinu 3 месяца назад +1

    Some nice languages that will never reach the attention of mainstream.
    1. D (OOP language with optional GC)
    2. C3 (Procedural language that deserves Better C)
    3. Odin (Improved C with pascal & Go style)

  • @finndriver1063
    @finndriver1063 7 месяцев назад +3

    +1 for Gleam, but wish Clojure had been in here. I guess 2007 is a too old, but 1.0.0 was much more recent.
    I think it would be interesting to compare some 'old' languages still in use, but with their newer features.
    Think Fortran, C, Common Lisp, Erlang, Haskell, Ada, Smalltalk, Pascal for example.
    For example, I think CL's tooling is superb, and Haskell's is now good even though it had a bad reputation. Smalltalk is OOP, but not as you know it, and Erlang has some of the cleanest loveliest code I've ever seen. Fortran is quick and I find it quite simple to read for whatever reason.
    If you need the list to be 10, then perhaps add Forth, Cobol, Eiffel or Prolog if you're up for a challenge.

  • @thavith
    @thavith 7 месяцев назад +2

    I really want to use Rust or Swift (not heard of Gleam so will check that out). Having said that, I love JS for the work I do (Node / front), but tend to only use the ES6+ stuff (don't have to maintain older 'smelly' code so much).
    I should build a Swift version of Node (I am sure it exists out there somewhere)

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

    you need to dig more to understand nim, its more of a wizard thing

    • @tom-delalande
      @tom-delalande  8 месяцев назад +5

      You're probably right, I'll have to dedicate more time to it to learn it probably. Based of the comments I think Nim was a big skill issue for me

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

    @2:39 seams like existing.date is being compared to the un-cleansed date... should be probably just `date` instead of `transaction.date`

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

    Nice vid, informative: would love to see this across different tasks. Rust being a joy to read is a bit on the nose however.

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

      Not sure what you mean about that last part. Is rust really bad to read? Compared to what?

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

      @@mikkelens obviously elements of personal preference, but Rust is well known for correctness not for being a joy to read. Ruby is a joy to read, APL is a nightmare, and Rust lies somewhere in between. My 2c.

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

      ​​​@@mikkelens Rust is basically impossible to read if you are newer to the language, especially when it introduces new concepts like borrowing and lifetimes. Meanwhile, most programmers can just see Go and understand what it does even if they barely use the language.
      Other than that, it's preference. I come from a Python background, so I found nim to be easy for me to read while zig being the hardest in these examples. Other people may prefer verbose language with more information, or c-style curly braces. It's all what you grown familiar with.
      However, if you remove that, my point still stands that Go is probably the easiest in general for anyone to read here.

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

    Cool video, you could try Rescript or more FP oriented languages to see if it's more to your liking

    • @tom-delalande
      @tom-delalande  8 месяцев назад +2

      I've been thinking about Rescript a lot, I'm tossing between trying to learn either that or Elm.

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

      @@tom-delalande both are awesome, I believe there is more people using Rescript nowadays thought (it might not be a valid criteria for you)

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

      ⁠​⁠​⁠@@tom-delalandeyou should try Clojure, though you might not like it since it’s dynamic

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

      ​@@tom-delalande Elm wouldn't be a wise choice if you ever intend to do server side rendering (or program for nodejs/bun)

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

    To be fair, I don't know if there was a much better way to handle that rust match nest. The language kinda seems to promote it

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

    As someone who uses Kotlin daily, it's not easy to set up on Windows. Try it on Linux it's much easier. The tooling of Kotlin is basically locked behind Maven or Gradle.

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

    Crystal not requiring brackets when calling a function is actually not a good thing - it means that passing a function as an argument into another function is harder, because by default the function will be called and the value passed in, so you need a workaround (as with Ruby). Crystal is not like Haskell where a function with no arguments is actually just a value

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

      The intention is that you should use blocks to pass functions. Thereby is is sorta by design that you shouldnt pass a function as an argument, instead it should be passed as a block argument.

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

      @@dragonyeet2273 how about if you want to pass multiple functions?

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

      @@thomasgeorge5261 , never had that scenario. Luckily is a block when it is parssed by a method a proc and you could pass multiple procs to a method using normal arguments. If I have a method called boo, it is a simple as foo = ->boo. And now foo is a proc of the method boo or a function pointer in other words.

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

    Seeing all those indentations is killing me

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

    11:16 This error probably means that you tried to free a struct from some allocator (error trace says std/mem/Allocator.zig), but the free function only accepts pointers to the memory instead of the real data.
    I don't really like Zig's compile error displaying when the error comes from the standard library (for example std.fmt) since it doesn't say where you wrote the bad code but only tells you that somewhere in your code, the error happened (like here). I have high hopes in Zig and I think that this will soon change for the better.

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

    Dart is awesome and very underused, prob. because people think it can only be applied to Flutter

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

    I really think Swift has the right balance of features, safety, expressibility, I am glad to see it well represented here. BTW It does not use GC. One thing I would like to have seen is a discussion of generics handling. I think Swift shines here.

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

    It would have been nice to get some information about the popularity and who uses the more exotic languages

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

    11:23 zig has union types which are actually tagged unions under the hood. If you try to access a member of an union which is not active it will result in an error. You have to use a switch statement (an if statement would probably work too) to check which union member is active and only then you can use its payload. Example:
    const Event = union {
    key_down: i32,
    mouse_moved: struct { x: i32, y: i32 },
    };
    var event = Event{ .key_down = 65 }; // 'a' button pressed, .key_down is 'active', accessing any other union field is an error
    switch (event) {
    .key_down => |key_code| {
    // do something with the keycode
    },
    .mouse_moved => |pos| {
    // do something with the mouse position
    },
    }

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

      That is called exhaustive pattern matching if you are interested about the name :) very good feature more and more language start to add or already have. Of course python is not one of those one lol

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

      @@gaxkiller yes exhaustive pattern matching is related to tagged unions but the error was specifically because of the access of inactive union member. Zig allows you to access a union field if it is active without pattern matching

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

      @@gaxkiller That's not exhaustive pattern matching, that's accessing the wrong field of the union.

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

      @@fredesch3158 This problem does not exists in good language, not aware of that

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

      @@gaxkiller What? It definitely does, if you try to access the wrong field from a union this is a standard error? You smoking?

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

    With that feature list at the start, I was thinking f# would be a perfect match

  • @ANONAAAAAAAAA
    @ANONAAAAAAAAA 7 месяцев назад +3

    Honestly, choosing programming language is rather insignificant compared with choosing your specialty.
    Specialties includes: mobile app, frontend, backend(startups), backend(enterprise), embedding system, infrastructure, etc...
    Each specialty requires tons specialized knowledges and programming languages are just one of them.
    For example, backend dev requires knowledges about databases like table design, indexing, SQL, locks and transactions, execution plans, query tuning etc..., and these are a lot harder to master than any programming languages since you have to play with real world production systems to actually understand them.
    Once you understand how to build specific type of apps like backend app, mobile app etc..., changing the languages is not so difficult for the most of cases.
    Choosing languages is like choosing kitchen knifes as a chef and choosing specialty is like deciding the dishes to cook from Italian, French, Chinese or Indian.
    So I would suggest fresh juniors who's entering this industry to pick up whatever languages which are likely to give you industry experiences you want, rather than hopping "modern languages" one after another.

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

      True, except for most platforms other than backend and maybe desktop dev there's really no choice. FE - JS/TS, Android - Kotlin, iOS - Swift. You pick a specialization and you have to stick with the language that is used there

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

    Honestly, I really like rust but working when I have to write a bunch of just regular regular code is absolutely by far. The best option for me. It’s easy, it’s readable, The standard library is great and super quick to just get things done.

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

    21:17 Bro insulted me without even knowing me 😀

  • @felixmason8752
    @felixmason8752 3 месяца назад +1

    should add f# it’s old but evolving