Golang Error Handling Is Better Than You Think!

Поділитися
Вставка
  • Опубліковано 23 січ 2025

КОМЕНТАРІ • 167

  • @anthonygg_
    @anthonygg_  Рік тому +2

    ► Join my Discord community for free education 👉 discord.com/invite/bDy8t4b3Rz
    ► Become a Patreon for exclusive tutorials 👉 www.patreon.com/anthonygg_
    Thanks for watching

  • @badrbadr3793
    @badrbadr3793 Рік тому +43

    "if you like try-catch, you're dead inside and you don't realize it"
    That was the funniest shit i heard today lol

  • @goocarry_yt
    @goocarry_yt Рік тому +79

    What a dangerous mix of pure programming experience and smth like standup comedy, best content I ever seen))

  • @hvaghani
    @hvaghani Рік тому +63

    try-catch exception feels like something unexpected happened and everything is in panic mode until someone catches it. But in case of golang, it is smooth and peaceful. No need to panic if something didn't go as you expected. Go lang's error handling really changed my perspective about "it is really bad" vs "it's okay if it didn't work". For example, index out of the range is really bad, it should not have happened vs oh I couldn't write to the file because the file didn't exist. In other languages, both are treated as the same.

    • @soyitiel
      @soyitiel Рік тому +3

      Exactly. Even the fact of calling errors _exceptions_ hurts our ability to handle them corrently, treating them as if they were impossible to happen since they are just the exception to the rule, when in reality they are inescapable, just another of life's certainties

  • @jed271
    @jed271 Рік тому +30

    People hating about golang's error handling are 99% coming from programming language that uses try catch

    • @nefrace
      @nefrace Рік тому +4

      Came to Golang a half year ago from Python and JS and I actually like this way of error handling.

    • @MarcelRiegler
      @MarcelRiegler 11 місяців тому +1

      Or they know that try catch isn't the only alternative to error handling. Rust has the best error handling I have ever seen.

    • @Rakstawr
      @Rakstawr 11 місяців тому

      ​@MarcelRiegler agreed, the optional is one of the features that I have heard the most requested

    • @arminmatthes
      @arminmatthes 10 місяців тому

      Wouldn't say I hate about them, but I was confused until I saw this video.

    • @ninthsun
      @ninthsun 9 місяців тому

      @@MarcelRiegler indeed. Especially the idea of removing "null" from programming makes the program so much clear and error-less.

  • @BinaryAdventure
    @BinaryAdventure 12 днів тому

    Anthony, this is a great video and you are an excellent teacher. You have single-handedly changed my mind about Golang in general, especially wrt error handling. I agree with you that sometimes a LITTLE verbosity and clarity is very important in programming, and that there are "ways most popular languages have done things" that should be respected for global understanding. You are pretty spot on about Rust as well, as I learned it way back in 2018 (I even have tutorial videos on my own channel lol) and looked at some code the other day and could barely even understand it anymore.... WHY!?!? Because what you said.

  • @PandaMoniumHUN
    @PandaMoniumHUN Рік тому +35

    It's not about pattern matching, but about having the option to easily throw the error up to the caller. A lot of the times when you receive an error you'll just immediately return it because you do not want to handle it locally (it's the case for most libraries, let the user of your library decide what to do about the error). In that case your program is going to be full of "if err != nil { return err }" clauses. It's even worse if you call methods in your error recovery code that can also throw errors, because you'll even end up embedding error recovery clauses. In Rust you just put a "?" at the end of the line and in case of an error/none result you'll automatically throw it up, no need to spell it out in the code. Not only that but a proper Result/Error type allows you to do optional chaining, map to a different thing, etc. Having these dumb error values without proper error typing or even stack traces (which is critical for production applications), I don't see how this is better than any of the other alternatives.

    • @bionichound3725
      @bionichound3725 Рік тому +11

      This sums it perfectly. I stopped watching shortly after he claims he’s a programming god with billions of hours of code over hundreds of programming languages. I’m not opposed to verbose error handling, but go’s lack of macros make it such that cascading errors up the callers is such an annoyance (think of a web server that has a generic error handler middleware). You can still implement the monadic style chaining in go, but because it’s not a macro it won’t benefit from short circuiting when an error occurs. All in all, go’s error handling is fine. It’s not the worst (I prefer it over Python), but it’s not the best (rust is much better)

    • @anthonygg_
      @anthonygg_  Рік тому +1

      You the man

    • @viktorshinkevich3169
      @viktorshinkevich3169 Рік тому

      Chaining the successful path is the money here. Rust ? is just a sugar, but ability to focus and declare successful flow of execution makes it much easier to reason about the code.
      Anyone can create an Option type in Go using generics, but how to create a proper chaining without sum types? Rust Enum is where Rust is a killer from my perspective.

    • @viktorshinkevich3169
      @viktorshinkevich3169 Рік тому

      @@bionichound3725
      > You can still implement the monadic style chaining in go
      How can you do that?

    • @angeloceccato
      @angeloceccato Рік тому +2

      Go handling is better than exceptions, but zig, swift, rust also the elvis operator for early returns in kotlin are less verbose and noisy than "if err != nill { return err }"
      the Happy Path of function is ofuscated by each trivial error i don't want handle but propagate out. When i want propely handle the error "err!=nill" is ok.
      Then the nil handling in go is another topic...

  • @TheIntervurt
    @TheIntervurt 25 днів тому

    I had a good laugh at "maybe you guys feel dopamine when handling an error like that" then lost it at the userJustFarted example, brother you are such an authentic character 😂

  • @grise123
    @grise123 Рік тому +3

    i learned to love this, i love the explicity of things on golang , no tricks or some hacky things for me is good

  • @insert-name1500
    @insert-name1500 11 місяців тому +2

    "What do you expect?" Had me rolling!!!

  • @nX-
    @nX- 9 місяців тому +1

    I think that only the "err != nil" is a bit redudant. An unwrap feature for the error would make things much more readable and smaller. This would be enough and readable: "if err := Foo() { return err }"

  • @gabrielseibeldev
    @gabrielseibeldev Рік тому +7

    UserJustShitTheirPants cracked me up

  • @remyclarke4020
    @remyclarke4020 Рік тому +7

    The problem with his form of error handing is that you could access the value even though there is a error.
    Other than that, it works, and is far better than random sentinel values.
    Opinionated, but overall great video.

  • @ericng8807
    @ericng8807 Рік тому +13

    as long as it's not try-catch 👌

  • @ThomasWSmith-wm5xn
    @ThomasWSmith-wm5xn 6 місяців тому +1

    Iv never heard anyone be able to hold onto that argument. They either write in a language that lets them get away with writing a lot of errors in their code, or they were used to a catch all super vague errors that doesn't tell you what you need.

  • @arminmatthes
    @arminmatthes 10 місяців тому

    I literally asked a Golang colleague about this a month ago, and he couldn't really explain. Thanks for the great video!

  • @ja31ya
    @ja31ya Рік тому

    The best analogy I've ever seen in a programming tutorial, hands down. Laughed my damn ass off 🤣🤣

  • @ryanleemartin7758
    @ryanleemartin7758 Рік тому +3

    Love the content! In Rust, the ? is pretty incredible though. It does one thing, returns early on error. It's one of my favorite features of the lang. Having said that, I'm very interested in getting into Go.

  • @silverhairs
    @silverhairs Рік тому +1

    6:11 - 7:55. I love these examples

  • @cryptobarboss
    @cryptobarboss Рік тому +9

    I came from writing C# code for 8 years but for some reasons I like this approach for error handling, especially it's very convenient when we decorate couple of functions and return error type which allows you to deal with different kind of error at one place (for logging or showing response to user)

  • @jittudwivedi6667
    @jittudwivedi6667 Рік тому +9

    I have been programming in golang for almost a year and i feel error handling in go is the best i am feeling i am having control over those error ,i never liked try catch

  • @marl3x
    @marl3x 10 місяців тому

    11:44 love it, and I completely agree, sometimes I think languages try to solve problems that don't exist that make it harder for everyone else to understand them. Go's "plain stupid code" is really nice.
    What I do not like is the implicit contract with the developer, that you need to handle the error. If you have a "Result" type you need to unwrap it, and the error handling will happen right there, where the call happened, and you can be sure you are doing it correctly. In Go you have an optional error that you SHOULD handle, but are not required to, otherwise you can easily fuck up because of the concept of zero values, and in my opinion that's really dangerous. In my app I've now had a few spots where I've implemented the error handling wrong. Luckily I cought my mistake, but I don't like that this is even possible, and when you begin to add gourotines with asynchronous error handling into the mix, it gets even worse.

  • @minskiypeterburg3575
    @minskiypeterburg3575 Рік тому +8

    I think the ugly part is not that functions return error values, but that you always have to check if err != nil even when you just want to propagate error to the caller, in rust you can just use ? operator to say if there is an error then return it if not give me the actual return value, it would be nice if golang had something like this, so you can stop writing if err != nil {return err}

    • @minskiypeterburg3575
      @minskiypeterburg3575 Рік тому +1

      I don't even know rust well enough, but I understand what ? means and it's great when you don't want to handle error, like when you functions just reads a file, you open it and get file not found error, you don't care so you write ? to return it to the caller, let him handle this situation

  • @dranon0o
    @dranon0o Рік тому +3

    When you want to return value + error, you can also do
    var foo string
    var err error
    if foo, err = bar(); err != nil {
    }
    I took the habit within my funcs to declare the vars before BUT only when I already figured what i wanted or have to do, so as a small "refactoring"
    Useful for big functions that call others

    • @nodidog
      @nodidog Рік тому +3

      You can only use foo within the error handling block though - it isn't shared with the surrounding scope! So only really suitable for when you plan to discard foo

  • @sarrahman_dev
    @sarrahman_dev 3 місяці тому

    In rust, you can use the ? operator to easily handle errors from your example use of match.

  • @MesheeKnight
    @MesheeKnight Рік тому +8

    I dont miss the try, catch, finallt, try, catch time. clear, simple, explicite. This is the way of the Golandorians.

  • @transaphonic
    @transaphonic Рік тому +1

    Haha I've been saying this Philosophy for years... So glad not everyone is just jumping on the latest bandwagon... You rock👍

  • @germantoenglish898
    @germantoenglish898 Рік тому +1

    If he just farted I wouldn't be too worried, but if he shits I will try to catch it in a diaper.

  • @HiepDuong-q8f
    @HiepDuong-q8f Рік тому +3

    1. by default, go encourage gopher to ignore all errors (forget the if err!= nil won't trigger any warning). I wish golang to do the reverse and always ask for gophers to handle errors or explicitly ignore it.
    2. chaining error to have a "call stack" is not obvious. eg: you have a call b call c call d, and d returned err, you wanted to handle in a, and you want that b, c enrich more info to the original err

    • @HiepDuong-q8f
      @HiepDuong-q8f Рік тому

      knowing that some third-party linter will give warning for none handling errors, some non standard lib will help to chain errors together..

    • @a-yon_n
      @a-yon_n Рік тому

      I wrote something for me to automatically deal with errors in Golang, it goes like this:
      res, err := goext.Try(func () int {
      val1 := goext.Ok(dep1())
      val2 := goext.Ok(dep2())
      return val1 + val2
      })

  • @ГеннадийОловянников
    @ГеннадийОловянников 10 місяців тому

    I think handling errors immediatly in every logical step and level is a vast contribution to the program stability. I am using PHP framework and it's common thing here to catch in common error handler something unexpected from framework's core with 20-lines backtrace log and it's difficult to understand what caused the error - it's like figuring out what happened at my home when I was at the office

  • @baxiry.
    @baxiry. Рік тому +3

    This is the first time I hear an opinion stemming from experience unaffected by propaganda
    By the way: I'm seeing other languages trying to imitate Go's error handling. Especially Typescript and JavaScript.

  • @arminmatthes
    @arminmatthes 10 місяців тому

    At my college, the professor actually tried to convince us, that a function should only ever have a single point of exit, meaning we should only ever have one code path return execution context back to the parent function. In his opinion, early returns / guard clauses were of the devil and should be avoided at all cost. He would even deduct points for not following this in exams.
    He would much rather have us write deeply nested spaghetti code littered with dozens of "if x then ret := y else ret := z" statements. To this very day I simply cannot believe how stupid this "advice" is and how many poor students might actually still be following this rule to this day. Thinking about this makes me wanna cry. Out in anger. I hope that prof frequently has his sleeves slipping down and getting wet while washing his hands.

  • @ArielCacha
    @ArielCacha Рік тому +5

    The Golang approach is not bad, but I think it needs some syntactic sugar to make the code easier to read. When you read those if-err statements, the function ends up being in the middle of the sentence, making it take longer to scan and understand what's being done there. And when you read a lot of code like this, you start feeling tired much more quickly than with other languages.

    • @weebney
      @weebney Рік тому

      I’m pretty sure this is an intentional language design “feature.” Thinking about it, they could have easily added the ternary operator to make the error handling idiom extremely short. In Go, though, you see `err := ` and immediately know you have a function with side effects that is being intentionally treated differently for a reason. You really should have to look hard at the line to see what the function is doing- there would be no error handling attached if that wasn’t the case. I can only imagine that this has saved more than a few asses.

  • @lilzin69
    @lilzin69 Рік тому

    go error handling is ok.. but i think go should learn a little with zig or rust
    code like this, I think, will be nice:
    value := try foo() // returns the error if foo() fail
    or
    value := foo() catch err {
    // do something with the error
    }

  • @vitiok78
    @vitiok78 Рік тому +6

    I personally think that exception based error handling is a nightmare. It leads to smelly code. Sometimes you just don't know where that exception is handled. You MUST deal with errors right there where it happened. You'll become ten times better developer if you do that.
    I even want a compiler option to disable the ability to omit errors entirely)

  • @GiovanniDiSanto
    @GiovanniDiSanto Рік тому +11

    I would like to start saying that I have seen the full video and I agree with most you are saying. I found the simplicity in which Go handles errors both effective and clear, especially when you have to properly handle an error or add information to the context before propagating it. It is way more readable that the try/catch statement when you want to recover from an error and let the program "fix" what happened.
    What most people do not like is the error propagation when you are not interested in: handling it where it occurred or adding extra information to the context. When just propagating the error is pure boilerplate "if err != nil {return err}", we should generally add extra information with fmt.Errorf but this is not always the case. Of course, if the application does not have a lot of logic layers this is okay, but for some type of applications layers are inevitable to properly segregate responsibilities. A common example is a rest api service which is usually composed by few layers: repository, service, controllers etc. If an error happens in the repository the application logic needs to propagate it till it reaches the handler where the appropriate status code and body can be returned.
    Like you, I think the "return" keyword should be preserved when propagating because it makes clear the flow is exiting the function... I would just add a little bit of syntactic sugar when purely propagating with not extra information context. I am not a language expert but I suppose a new keyword or something equivalent could be added... even something along the lines of: "res, (return err) := MyFunc() or res, (return err != nil) := MyFunc()" would make a lot of people happier and more or less preserve the identity of the language. This is just an example, I am pretty sure the smart engineers working on Go can come up with something way better than this.
    Lastly just a constructive criticism, I think you are a great UA-camr but things like "If you do not see this, I am sorry for you guys" or "trust me because I have way more experience than you'll ever have" are not really effective when trying to justify your position about something... people generally expect something more elaborated than that. Just my 2 cents, of course.

    • @anthonygg_
      @anthonygg_  Рік тому

      Thank you for this amazing comment. I 100% agree with this. You make a lot of sense.

  • @manfromeridani
    @manfromeridani 10 місяців тому

    At first, the Golang way of handling errors didn't fit my preferences. Now, I fall in love with Golang 😂

  • @daviddragomir9156
    @daviddragomir9156 Рік тому +1

    I cloned ur vscode setup but how I can put the numbers? Also relative numbers

  • @Convictedization
    @Convictedization 10 місяців тому

    Is this targeted against rust?

  • @myounus96
    @myounus96 10 місяців тому

    "I am training you guys to have a longer attention span" 😂

  • @iajitpatil
    @iajitpatil Рік тому

    Halfway this tutorial and I never knew you could relate programming algorithms with a user farting and shitting. This is amazing.

  • @snatvb
    @snatvb Рік тому

    bad is that we have nil
    if you wanna return tuple with error, you may get nil, you never sure that there is real value
    worse when it's numbers, there will be 0 - it may leads to UB

  • @enriquellerena4779
    @enriquellerena4779 Рік тому +1

    II like the rust way of hand long the error with the .or_else(). Very small and concise for what i want to do

  • @PatMaddox
    @PatMaddox Рік тому

    Rust’s ? suffix takes 2 seconds to get - once someone explains it (and if you have enough experience with other languages, you may grok it off the bat). So it may seem small, but your point is well-taken: anyone who has ever shipped code can look at golang error handling and immediately understand it, no explanation required. That does seem to be one of go’s big selling points: you can take pretty much anyone off the street and they can implement a functional change pretty quickly. Whether they’ll do it well is a different story…

  • @ninthsun
    @ninthsun 9 місяців тому

    The question has to be changed. I think people are fine with error handling in Golang but feel tedious and descriptive for duplicated syntax sugars of all those if statements.
    As I started programming TS, I really love the way how Rust and Go and some other young programming languages handle error. The problem with JS/TS is you propagate error with "throw" and expect someone handles that error magically. As a result, the code might look clean and nice, but the way how error is handled is so complicated or maybe miss some important exceptions as they are handled by common error handlers in the upper stack.
    So, it's kind of trade-off. If you want some short code with minimal duplication. Then you'll have to abstract everything in a fear of code duplication. However, if you embrace some code duplication, the code may look bit dirty, but it's so much clear and less prone to unhandled exceptions.

  • @avid459
    @avid459 Рік тому +3

    What he is basically saying is, 'My way or the Highway'. Go community in general is exactly like this.
    200k+ devs are exactly the devs who don't like Golangs verbosity.
    func A(){
    doA()?
    doB()?
    doC()?
    }
    what they are fighting for is human time to learn a codebase which is getting higher as the amount of code only increases, I learnt the ? operator in the first hour of leaning rust, I can quickly scan the three lines and know what the function is doing, now if you sprinkle go's error handling, you know the above function will look like. People hate Go codebases as 40% of the code is just error handling.

    • @anthonygg_
      @anthonygg_  Рік тому

      200k+? That looks like my yearly salary

  • @Ross96D
    @Ross96D Рік тому

    Have u see Zig error handling?

  • @ralphlorenzo9473
    @ralphlorenzo9473 Рік тому +1

    🙌 thx for you work

  • @AK-vx4dy
    @AK-vx4dy 11 місяців тому

    @16:11 Most important is to have *CLEAR* signal that you *SHOULD* check error condition or use some *VISIBLE* and/or *HARD* or *UGLY* way to skip this check:
    _ := Foo() in GO or .unwrap() in Rust.
    People who say it is wrong, are exceptions and try/catch fans... wich are literaly *GOTO* in disguse...
    Maybe it is not beautiful but definietly not bad design or wrong. Maybe one day GO will have some "shorcut" for this idiom or people will use some library.

  • @viktorshinkevich3169
    @viktorshinkevich3169 Рік тому

    4:23 result by itself solves nothing and as you said tuple (value, err) makes the job done even better.
    But what result gives is ability to declare a successful path as it should be and deal with errors separately.

  • @enfy1337
    @enfy1337 Рік тому +2

    lmao "User just shit their pants. that's problematic!" Thank god programmers don't have to actually deal with this kind of problematic error :)

  • @definitelynotrohan
    @definitelynotrohan Рік тому +1

    cool video!

  • @wwnnbb9482
    @wwnnbb9482 Рік тому +1

    for tl dw: dude would show you how to write func Foo() error {}; func Bar() error {}; for 20 minutes

    • @anthonygg_
      @anthonygg_  Рік тому

      When are you going to make more than 50k a year? Let that sink in little boy

  • @ignoreyour6326
    @ignoreyour6326 Рік тому +1

    What is easier to read:
    func foo() throws IOException {
    read();
    write(...);
    ...
    }
    or:
    func bar() {
    _, err := tead()
    if (...) { return err;}
    _, err := ...
    if (...) { ...}
    }
    Exceptions, when implemented correctly lets you focus on the code, not the error handling aspect.

    • @Jason-xw2md
      @Jason-xw2md Рік тому +1

      yes, exceptions are very good at helping you focus on if a nested function call in some library, or unfamiliar part of the codebase you are using throws an error. Hope it has good documentation! If it doesn't, you can always just wrap everything in try catch, and have "error handling"(printing out an error, very useful)

  • @thejuanpa88
    @thejuanpa88 Рік тому +3

    this is still a very bad way to handle errors imho, there is literally no reason for not having a one liner for error-returning functions handling

  • @iamworstgamer
    @iamworstgamer Рік тому +1

    i used to hate it but i began to appreciate the genius of it because it really forces you to decouple your code

  • @denisprogman
    @denisprogman Рік тому

    I've got so much laugh )) thanks man!🤣 moreover it's useful info!

  • @donnacasterr6223
    @donnacasterr6223 Рік тому

    Returning error is only superior to Try Catch in some cases.
    Rust, Vlang, Zig all have far superior ways of handling errors where you can easily decide to deal with it our bubble it up to the caller.

  • @3ckortreat
    @3ckortreat 10 місяців тому

    is it scottish accent or belgium?

  • @Arunnn241
    @Arunnn241 Рік тому +7

    I don't think golang has bad error handling. I think something to reduce the amount of keystrokes would be nice tho. Someone should make a vscode extension

  • @thingsiplay
    @thingsiplay Рік тому +1

    If you want proof a point, never say others don't understand just because they have a different opinion than you. Yes, there are some people who don't know what they are talking, but on the same time, there are people who know what they are talking. I will learn and build my own opinion AND respect others opinions.

    • @anthonygg_
      @anthonygg_  Рік тому +1

      You have a point here.

    • @thingsiplay
      @thingsiplay Рік тому

      @@anthonygg_ 1 month later and I am currently learning Go, diving into the errors a bit. The error handling could be better, coming from Rust, but it is not as bad as people told me. In fact I already did error handling in Python in a similar way with multiple return values! I like this control, but it could be improved.

  • @AaronHeld
    @AaronHeld Рік тому +2

    I have over 25 years of programming experience at both Fortune 50s and Unicorn startups.
    I have personally mentored 100s of software engineers and led countless in house training sessions.
    Never in my life have I seen domain event error handling expressed so elegantly.
    I am updating my slides today and adding a relieveGas() function to demonstrate how we operationalize laptop code and get it ready for real use. Handling the domain events of Farted and Shitted is brilliant. We can even expand the context because handling a domain even of Shitted for a baby should be a very different process then handling that even for an adult.
    The analogy is brilliant and accessible.

  • @datguy4104
    @datguy4104 Рік тому +1

    I don't remember who it was but his argument against something like JS error handling is that you have no idea what could even throw and error and don't even know innately where to use try/catch... Go might be "annoying", but it teaches programmers to be wary of errors in the first place and makes it plain as day what's happening. It's boring but great.

  • @tomasnevoral9246
    @tomasnevoral9246 Рік тому +4

    I like golang but it would be nice to have similar like rust error handling

    • @NoxyYT
      @NoxyYT Рік тому +2

      Just ? operator to propagate error would have been great, it doesn't even need options/results.

  • @moistness482
    @moistness482 11 місяців тому +1

    Anyone who thinks go's error handling is tedious clearly hasn't tried rust.
    p.s. nothing is as tedious as finding out a random function from a library can throw and you don't even know it until it happens.

    • @anthonygg_
      @anthonygg_  11 місяців тому

      Exact. Rust people think their error handling is better, but they just call unwrap() on everything

    • @androth1502
      @androth1502 10 місяців тому

      everything is tedious in rust.
      odin does better error handling.

  • @codecoffee8363
    @codecoffee8363 Рік тому +1

    I think you will talk about error type, error wrap, error codes 😂😅

  • @webstradev
    @webstradev Рік тому +2

    Great Video! Great Topic!

  • @garciajero
    @garciajero Рік тому

    6 months ago a programmer of your experience could be returning generics already more than int,error...

  • @osagie6862
    @osagie6862 Рік тому +3

    Shit, Fart 😂 love your content.

  • @AK-vx4dy
    @AK-vx4dy 11 місяців тому

    @13:12 It is not bad... it syntatcit sugar for almost the same lines you had before....
    @13:15 Oh man...... ? in Rust have nothing in common with ? in JavaScript !!! In rurst it propagates error up in JavaScript it handles undefinded/null values "silently"
    @13:54 No one will understand := if not programing in go 24/7 :) (or have someting to do with pascal in some way) :D

  • @your_skyfall
    @your_skyfall Рік тому +1

    I don't know if you're serious about bragging your YoE (4:35) into this argument and 10x your viewer will ever have, defending a subjective opinion (4:15), but that makes you sound much less credible.

    • @anthonygg_
      @anthonygg_  Рік тому

      Take it with a grain of salt. No need to take everything I say serious.

    • @your_skyfall
      @your_skyfall Рік тому

      @@anthonygg_ I see, would rewatch again with a table spoon of salt

  • @cangurdal9264
    @cangurdal9264 Рік тому

    I checked my playback speed. I thought it was at 1.50x

  • @P3PPING
    @P3PPING Рік тому

    The thing I love about go is that the different between a Junior and s Senior isnt the "cool syntax" they use, but the smart way they solve the problem.
    Go says that language choice matters so much that we designed it not to matter.

  • @aar021
    @aar021 Рік тому

    Do not mind it at all. I like Rust’s better. You should learn Rust. You may like it. I love both. Thank you for the video.

  • @esra_erimez
    @esra_erimez Рік тому

    3:40 🤣

  • @paulfrischknecht3999
    @paulfrischknecht3999 Рік тому +1

    hilarious 😂

  • @Cruzylife
    @Cruzylife Рік тому +1

    this made me laugh so much

  • @TB-tv2zf
    @TB-tv2zf 10 місяців тому

    Well at least try/catch catches "panics", whereas I absolute hate Go's recover.

  • @gabrielseibeldev
    @gabrielseibeldev Рік тому +2

    Hey, what's that editor theme? Good take on errors 🫡

    • @anthonygg_
      @anthonygg_  Рік тому +2

      Gruvbox and some vscode settings. There on my github

  • @vitorhmtts
    @vitorhmtts Рік тому +1

    yeah, this is better than try cath because at least errors are values, you return and should at least explictly ignore them... but there are better ways to handle them too, like the rust approach

    • @vitorhmtts
      @vitorhmtts Рік тому +1

      to clarify (because what you said about rust is wrong): the Result type is an Enum, not a Struct. it means the Result is an Ok OR an Err, so you CAN'T use the other value and explicitly ignore the error, as you can do in golang. if the return is the Return::Err variant, the Ok value simply doesn't exist, it isn't "nil" or "None", it doesn't exist. you HAVE TO handle the error or panic your program.

    • @anthonygg_
      @anthonygg_  Рік тому +1

      Agreed, my bad

  • @freeplayer2183
    @freeplayer2183 Рік тому

    this guy is the fucking goat

  • @sirnawaz
    @sirnawaz Рік тому

    Pretty bad justification! Why don't you look at Rust and the operator `?` and there are so many other functionalities on Result and Option that simplifies the code.

  • @airkami
    @airkami 8 місяців тому

    No thumbs up for you and I definitely won’t leave a comment!

  • @ThePandaGuitar
    @ThePandaGuitar Рік тому +1

    Lmfao 🤣 love this

  • @rolandinnamorato1953
    @rolandinnamorato1953 Рік тому +1

    Very convincing. Go is for tired (of bullshit) programmers

  • @airkami
    @airkami 8 місяців тому

    With all due respect, please figure out how to not pick up your breathing on the microphone. The listening will flow more smoothly

  • @RockTheCage55
    @RockTheCage55 Рік тому

    I have to disagree I love go but the error handling isn’t the cleanest. try/catch/finally (TCF) is the cleanest. Go error handling reminds me back in the old days of MFC/win32 api calls & having to inspect HResult (yuck). TCF forces you to deal with and errors..if you want to throw them away you can but if you don’t they will bubble up & your program will crash with & unhandled error exception & IMO this is the way it should be. My errors are generally handled in either middleware or put in with AOP. That’s why 99% of new languages use TCF

  • @juraev0056
    @juraev0056 Рік тому +1

    Informative function names

  • @mlntdrv
    @mlntdrv Рік тому +1

    So in short, back to error handling C-style. I can see why people dislike it.

  • @MaybeBL1TZ
    @MaybeBL1TZ Рік тому +2

    for anyone who didn't like error handling in Golang he's clearly a low value programer period.

  • @jianxue283
    @jianxue283 11 місяців тому

    There are so many "666"s here. 🤣 I'm genuinely curious, are you familiar with the significance of "666" in Chinese culture?

  • @Dethas1991
    @Dethas1991 11 місяців тому

    I hate try-catch, there's always problem with it...

  • @rekram1519
    @rekram1519 Рік тому +2

    It’s just so idiomatic idk why people hate on it

  • @lmtr0
    @lmtr0 Рік тому +1

    Who can read this? 😅 People that have 10+ more hours than I will ever have should as i read it very well LMAO

  • @sjakievankooten
    @sjakievankooten Рік тому +1

    You sound very Belgian. Am I right? 😅

  • @peculiar-coding-endeavours
    @peculiar-coding-endeavours Рік тому +1

    Errors as values is the way to go for sure. People like to laugh at GOTO statements, but then happily mess up control flow in their programs with throwing around exception throwing. On the scale of predictability at the cost of verbosity vs nondeterministic behavior while being able to easily throw exceptions, I'll err on the side of robustness any day of the week.

    • @anthonygg_
      @anthonygg_  Рік тому +1

      Amen

    • @peculiar-coding-endeavours
      @peculiar-coding-endeavours Рік тому +1

      @@anthonygg_ No need to reply, cause it's none of my business, but am I right to detect some Dutch accent there? More specifically the Flemish flavor?

    • @anthonygg_
      @anthonygg_  Рік тому

      @@peculiar-coding-endeavours Jup :)

    • @peculiar-coding-endeavours
      @peculiar-coding-endeavours Рік тому +1

      @@anthonygg_ Takes one to know one ;-) goed bezig

    • @anthonygg_
      @anthonygg_  Рік тому

      @@peculiar-coding-endeavours merci bruur

  • @stanislavus
    @stanislavus 10 місяців тому

    boost

  •  Рік тому

    so basicly there are no error handling, just a bunch of if statements and multiple return values all over the code :D and you say its better than try-catch, and its readable :D better error handling is one of the most requested feature in go, everyone knows its a piece of sh..t...

  • @AK-vx4dy
    @AK-vx4dy 11 місяців тому

    Somewhat "shitty" examples 🤣

  • @aslkdjfzxcv9779
    @aslkdjfzxcv9779 Рік тому +4

    i had to lookup when i heard, "userjustfarted." 🤣
    thought maybe it was your accent. no. it wasn't your accent. 😁

    • @anthonygg_
      @anthonygg_  Рік тому +6

      In 2023 its hard to get peoples attention. I try to be creative 😇