Learning Golang Context!! Never Looked At It!

แชร์
ฝัง
  • เผยแพร่เมื่อ 20 พ.ย. 2024
  • LIVE ON TWITCH: / theprimeagen
    Become a backend engineer. Its my favorite site
    boot.dev/?prom...
    This is also the best way to support me is to support yourself becoming a better backend engineer.
    Get in on Discord: / discord
    Get in on Twitter: / theprimeagen
    Got Something For Me to Read or Watch??:
    / theprimeagenreact

ความคิดเห็น • 43

  • @bennythetiger6052
    @bennythetiger6052 9 หลายเดือนก่อน +25

    Started learning go a week ago as a experienced developer and boy oh boy do I already love it with all my heart. It's all so easyyy and simple and straight to the point

    • @mazharansari7813
      @mazharansari7813 4 วันที่ผ่านมา

      It's Python but with compiler and blazzzinglyy fast.

  • @dv_xl
    @dv_xl 8 หลายเดือนก่อน +5

    I find that context as a kv store tends to get messy when it's really common in a codebase.
    This has perf overhead (contexts are trees, and key lookups are traversals) but worse it can lead to hidden side effects if a function differs it behaviour based on contextual information.
    It can be a lifesaver if you need to have a globally accessible request scoped value, but use with caution.

  • @gauff3r
    @gauff3r 9 หลายเดือนก่อน +27

    Hey Prime, we would love more of your takes on advanced Go topics.
    Thank you for your hard work!

  • @Mikenight120
    @Mikenight120 9 หลายเดือนก่อน +14

    Loving this Go content lately, adding all of them to downloads to binge watch 💯

  • @bryanenglish7841
    @bryanenglish7841 9 หลายเดือนก่อน +2

    Context is amazing. Watching you learn Go is super awesome, I’ve been with it for almost 10 years and it just now feels like Go is getting its due.

    • @gauravaws20
      @gauravaws20 7 หลายเดือนก่อน

      bryan your videos are awesome too. i remember there was so little good go content a couple of years go and I stumbled on your videos. I was starting a new job and your videos helped me ramp up. thank you.

  • @QuantumMechanic343
    @QuantumMechanic343 9 หลายเดือนก่อน +7

    Prime, using middleware to put things into a context is a super cool pattern.
    Let’s say you have the following route `/foo/:fooID/bar/:barID`. You could have a middleware package maintain a cache of the `foo` resource by its `fooID`. The middleware can pull the `fooID` from the path, and put the `foo` resource into the request context. This means that `bar`s handler doesn’t need to know the specifics of how to fetch `foo`, it just pulls it out of the context.
    If we add another route like `/foo/:fooID/grug/:grugID`, the ‘grug’ handler will also have access to the `foo` resource.
    As routes continue to be added under `foo`, you save yourself the trouble of putting in the boilerplate code to go fetch it.

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

      That's super interesting. Any code examples?

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

      I initially liked the approach, but mapping all values to `interface{}` within the context package of Go posed challenges due to its generic nature. To address this, I now define a struct with fields that are consistently required across different middleware handlers. This struct is passed as a parameter to handler functions, which improves type safety and enables syntax highlighting, making the code more maintainable. I remain open to other solutions that may be more efficient though.

    • @pookiepats
      @pookiepats 8 วันที่ผ่านมา

      The foo bar crap is so useless, if you can’t express a use case in real world terms for your relative domain then you’re just yanking to syntax

    • @QuantumMechanic343
      @QuantumMechanic343 8 วันที่ผ่านมา

      @ thanks for taking the time to share your thoughts. My example is trying to demonstrate how middleware and a context can be used to handle resource caching. I can see now that I’m making the assumption that the reader already knows something about resources on an HTTP server, and knows what resource caching is. To be fair to me, the comment was directed towards the creator of the video, who would be familiar with these concepts.
      In the example, `foo` and `bar` are generic names for resources, and the route structure suggests that each `foo` can own one or more `bar`. I can replace those words with something less generic though; let’s say we are working with multiple questions for a test, and that `foo` is a `question` and `bar` is a possible `answer` to that question.
      Let’s also say that our system also needs to support different types of questions (multiple choice, numeric input, etc), and that only multiple choice questions can have answers. This business rule means that if a user tries to add an answer to a question, we need server-side logic to reject the request.
      Let’s also say the operation to add a nee answer to a question involves a POST request to `/questions/:questionId/answers`, and that the body of the request would contain the answer. The request handler on the server would be able to use the request’s context to know the questionId, and the answer the user is trying to add to the question.
      In order to execute our business logic, the request handler needs to be able to use the questionId to determine if the question is of the multiple choice type. One way to solve this issue is to have a system that will return a question when given a questionId.
      Once implementation of this system could be a repository, which stores questions in a database and indexes them based on their the questionId.
      Another implementation would be to maintain a cache of questions indexed by their questionId in the server middleware. That middleware could then use the questionId in the request context to add the question to the context. That way, when the handler gets the request context it can now access the questionId, answer, as well as the question. From the handler’s point of view, this is all done without having to interface with any other system, and it doesn’t need to know how to fetch a question based on it’s questionId.
      This also means that other handlers that are under the `/questions` route do not need to have this knowledge as well! All of those handlers just get it from the context.

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

    The cast can not blow up because it’s one with two assignments (There’s probably a proper name for this): the casted value and ok (bool indicating if the cast was successful). This is even mentioned in the comment above in the example code.

  • @enzo.albornoz
    @enzo.albornoz 9 หลายเดือนก่อน +32

    Prime, ninja edition

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

      Will he update the thumbnails when he returns to normal… hmmm

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

      lol

    • @pookiepats
      @pookiepats 8 วันที่ผ่านมา

      It looks terrible 😂

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

    I do a DB lookup of a user by his token and then I put all the necessary info into context (key, value) and use it across the functions which have access to the request. It's just something you share data across functions within one request.
    No different from a React context, where you share data across components.

  • @maxpyte1119
    @maxpyte1119 9 หลายเดือนก่อน +2

    C# (sorry for the curse word), as said earlier, has it as 2 separate concepts: CancellationToken and HttpContext
    1)CT just basically passed inside of any async method, and internal method should manually check, when running continuous operation, is token revoked, and stop in this case.
    2)HC is basically storage for all request-scoped data, e.g. user identity, headers, request and response data, and it's shared between chains of async called method (because async in c# works as a state machine, so diff. threads, that work on 1 chain, should somehow now, how to have contrxt of request)

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

      C# MENTIONED

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

      IIRC there is no propagation of cancellations in C# (except manual)

  • @kevinkkirimii
    @kevinkkirimii 9 หลายเดือนก่อน +1

    Children cannot cancel the parent but they can cancel their own children's context derived from them. I have seen open telemetry using context in a great way

  • @uby2007
    @uby2007 9 หลายเดือนก่อน +1

    His hair is the same colour as the text string highlights. lol

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

    Love the learing with the Primeagen , would love to see more of this

  • @gabrielomane-yeboah
    @gabrielomane-yeboah 9 หลายเดือนก่อน +1

    Prime's brain is transparent now

  • @christopher8641
    @christopher8641 9 หลายเดือนก่อน +1

    17:28 real Dad moment showing through right there

  • @Ujjaval___
    @Ujjaval___ 9 หลายเดือนก่อน +4

    we can see through your brain .😂😂

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

    So they made dynamic variables. Isn't that what that is about, petty much, just dynamic variables implemented by hand?

  • @rpanda_old
    @rpanda_old 8 หลายเดือนก่อน +1

    "vim is crap if you want it to be like vscode"

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

    Does anyone feel like Go is the spiritual successor to Perl? No? Just me . . . .okay.
    Thanks for the video Prime!

    • @pookiepats
      @pookiepats 8 วันที่ผ่านมา

      Hell nah . Now there is a project called Go++ (compiles to Go) that would fit that description

  • @pollathajeeva23
    @pollathajeeva23 9 หลายเดือนก่อน +1

    Gen this is similar to C#' ish Cancellation tokens.

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

    Didn't think about the green screen when you got that hair, did you? :D

  • @Stupendousboy
    @Stupendousboy 9 หลายเดือนก่อน +1

    switchHairColorWithMustache()

  • @NiclasGleesborg
    @NiclasGleesborg 9 หลายเดือนก่อน +2

    Nice hair

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

    How did he make the page display in dark mode?!

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

      DarkReader, probably

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

    This talk explains context incredibly well imo: th-cam.com/video/mfgBhGu5pco/w-d-xo.html

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

    Good video

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

    Nice transparent hair.

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

    if you wanted js to be a backend language it would be terrble - node.js: am i a joke to you ?
    (yeah you are but anyway xD )

  • @Kfoo-dj4md
    @Kfoo-dj4md 9 หลายเดือนก่อน

    Probably can whip out a context like thing in Rust in an evening
    (I use Rust btw)

  • @int-64
    @int-64 9 หลายเดือนก่อน

    balding