Golang Error Handling Is Better Than You Think!

แชร์
ฝัง
  • เผยแพร่เมื่อ 13 ม.ค. 2025
  • ► Join my Discord community for free education 👉 / discord
    ► Become a Patreon for exclusive tutorials👉 / anthonygg_
    ► Follow me on Twitter 👉 / anthdm
    ► Follow me on GitHub 👉 github.com/anthdm
    In this Golang tutorial, I will show you that Golang's error handling is better than you think it is.
    #golang

ความคิดเห็น • 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 ปีที่แล้ว +42

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

    • @manfrombritain6816
      @manfrombritain6816 10 หลายเดือนก่อน +1

      this is why i watch this channel 😂😂

    • @ehSamurai3483
      @ehSamurai3483 8 หลายเดือนก่อน

      Learning code + jokes

  • @goocarry_yt
    @goocarry_yt ปีที่แล้ว +79

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

    • @weironiottan7166
      @weironiottan7166 10 หลายเดือนก่อน

      Lol😂 this guy cracks me up, love it

  • @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 ปีที่แล้ว +29

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

    • @nefrace
      @nefrace ปีที่แล้ว +3

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

    • @MarcelRiegler
      @MarcelRiegler 10 หลายเดือนก่อน +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 10 หลายเดือนก่อน

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

    • @arminmatthes
      @arminmatthes 9 หลายเดือนก่อน

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

    • @ninthsun
      @ninthsun 8 หลายเดือนก่อน

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

  • @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 15 วันที่ผ่านมา

    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 😂

  • @gabrielseibeldev
    @gabrielseibeldev ปีที่แล้ว +6

    UserJustShitTheirPants cracked me up

  • @BinaryAdventure
    @BinaryAdventure 2 วันที่ผ่านมา

    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.

  • @insert-name1500
    @insert-name1500 11 หลายเดือนก่อน +2

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

  • @ericng8807
    @ericng8807 ปีที่แล้ว +13

    as long as it's not try-catch 👌

  • @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.

  • @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 }"

  • @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.

  • @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

  • @arminmatthes
    @arminmatthes 9 หลายเดือนก่อน

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

  • @silverhairs
    @silverhairs ปีที่แล้ว +1

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

  • @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

  • @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)

  • @ja31ya
    @ja31ya ปีที่แล้ว

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

  • @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

  • @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.

  • @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.

  • @myounus96
    @myounus96 10 หลายเดือนก่อน

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

  • @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
      })

  • @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👍

  • @daviddragomir9156
    @daviddragomir9156 ปีที่แล้ว +1

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

  • @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

  • @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.

  • @ralphlorenzo9473
    @ralphlorenzo9473 ปีที่แล้ว +1

    🙌 thx for you work

  • @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.

  • @arminmatthes
    @arminmatthes 9 หลายเดือนก่อน

    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.

  • @manfromeridani
    @manfromeridani 10 หลายเดือนก่อน

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

  • @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.

  • @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)

  • @ГеннадийОловянников
    @ГеннадийОловянников 9 หลายเดือนก่อน

    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

  • @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 TH-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.

  • @sarrahman_dev
    @sarrahman_dev 3 หลายเดือนก่อน

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

  • @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
    }

  • @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

  • @ninthsun
    @ninthsun 8 หลายเดือนก่อน

    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.

  • @Convictedization
    @Convictedization 10 หลายเดือนก่อน

    Is this targeted against rust?

  • @Ross96D
    @Ross96D ปีที่แล้ว

    Have u see Zig error handling?

  • @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

  • @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.

  • @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

  • @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 :)

  • @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.

  • @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

  • @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…

  • @3ckortreat
    @3ckortreat 10 หลายเดือนก่อน

    is it scottish accent or belgium?

  • @denisprogman
    @denisprogman ปีที่แล้ว

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

  • @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.

    • @anthonygg_
      @anthonygg_  ปีที่แล้ว +1

      Thanks you so much

  • @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.

  • @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

    • @iggermanable
      @iggermanable ปีที่แล้ว +1

      Copilot helps a lot with that)

  • @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

  • @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

  • @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.

  • @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.

  • @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

  • @moistness482
    @moistness482 10 หลายเดือนก่อน +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_  10 หลายเดือนก่อน

      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.

  • @rolandinnamorato1953
    @rolandinnamorato1953 ปีที่แล้ว +1

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

  • @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.

  • @paulfrischknecht3999
    @paulfrischknecht3999 ปีที่แล้ว +1

    hilarious 😂

  • @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)

  • @garciajero
    @garciajero ปีที่แล้ว

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

  • @codecoffee8363
    @codecoffee8363 ปีที่แล้ว +1

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

  • @esra_erimez
    @esra_erimez ปีที่แล้ว

    3:40 🤣

  • @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

  • @freeplayer2183
    @freeplayer2183 11 หลายเดือนก่อน

    this guy is the fucking goat

  • @definitelynotrohan
    @definitelynotrohan ปีที่แล้ว +1

    cool video!

  • @Cruzylife
    @Cruzylife ปีที่แล้ว +1

    this made me laugh so much

  • @cangurdal9264
    @cangurdal9264 ปีที่แล้ว

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

  • @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

  • @TB-tv2zf
    @TB-tv2zf 9 หลายเดือนก่อน

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

  • @juraev0056
    @juraev0056 ปีที่แล้ว +1

    Informative function names

    • @anthonygg_
      @anthonygg_  ปีที่แล้ว

      Im trying to be expressive

  • @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.

  • @webstradev
    @webstradev ปีที่แล้ว +2

    Great Video! Great Topic!

  • @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.

  • @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

  • @osagie6862
    @osagie6862 ปีที่แล้ว +3

    Shit, Fart 😂 love your content.

  • @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

  • @airkami
    @airkami 8 หลายเดือนก่อน

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

  • @Dethas1991
    @Dethas1991 11 หลายเดือนก่อน

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

  • @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.

  • @sjakievankooten
    @sjakievankooten ปีที่แล้ว +1

    You sound very Belgian. Am I right? 😅

    • @anthonygg_
      @anthonygg_  ปีที่แล้ว +1

      Yes born and raised

  • @mlntdrv
    @mlntdrv ปีที่แล้ว +1

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

  • @ThePandaGuitar
    @ThePandaGuitar ปีที่แล้ว +1

    Lmfao 🤣 love this

  • @MaybeBL1TZ
    @MaybeBL1TZ ปีที่แล้ว +2

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

  • @jianxue283
    @jianxue283 10 หลายเดือนก่อน

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

  • @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

  • @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

  • @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

  • @stanislavus
    @stanislavus 10 หลายเดือนก่อน

    boost

  • @AK-vx4dy
    @AK-vx4dy 11 หลายเดือนก่อน

    Somewhat "shitty" examples 🤣

  •  ปีที่แล้ว

    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...

  • @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 😇