Real-world examples on optimizing .NET performance - Stefán Jökull Sigurðarson - NDC Oslo 2023

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

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

  • @coltyngregoryify
    @coltyngregoryify Год назад +24

    Maybe the best NDC talk AND THEY FILMED IT IN A HALLWAY

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

    Extremely well prepared talk! Big hugs to Stefán.

  • @martink.7497
    @martink.7497 Год назад +5

    Honestly, never heard of Channels and saw so many optimizations. Well done 👍

  • @desertfish74
    @desertfish74 Год назад +28

    why is there so much crowd noise in the background?

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

      Literally the PowerPoint code is displayed, you can hear him clearly n he speaks slowly.
      Being distracted by “this” noise says a lot about you n other likes how little things annoy/angry at.

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

      @@georgepagotelis I bet it has to be so much fun being around you

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

    I have a lot of experience in .NET, this conference is extremely interesting.

  • @PaulSebastianM
    @PaulSebastianM Год назад +3

    00:00 Intro
    01:20 Garbage collectio
    03:58 Reference vs. Value types
    05:16 Performance tips

  • @EternalVids
    @EternalVids Год назад +8

    Was this filmed in the middle of a busy cafeteria?

  • @wojciechmikoajewicz1983
    @wojciechmikoajewicz1983 Год назад +5

    ArrayPool doesn't have a reference to the array after rent, so not returning array to the pool mitigates the point of using ArrayPools but isn't dangerous - do not lead to memory leaks. You don't need to be orthodox and write some finalizers to be extremally sure that array will return to the pool on some edge cases (like exceptions).

    • @Stebet
      @Stebet Год назад +1

      Thanks for the correction. I had overlooked this :)

  • @BryonLape
    @BryonLape Год назад +4

    Who does the audio for tech conferences?

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

    4:46 "If you create a string, send it to a method, that method changes the string, it is going to change the original object." This is not true. Strings are immutable and modifications will return a new string.

  • @BrendonParker
    @BrendonParker 9 месяцев назад +1

    "But if it was to be run on different architectures... (fluke boom in audience) ... it would fail" made me lol 28:02

  • @weriohjiuhuih
    @weriohjiuhuih Год назад +1

    Isn't Channels same as the "new" Pipe API?

    • @gdargdar91
      @gdargdar91 Год назад

      Channels are made for asynchronous producer-consumer scenarios and they are generic, for any type T. The new pipe API works with raw bytes and provides automatic memory buffer management via memory pooling.

    • @weriohjiuhuih
      @weriohjiuhuih Год назад

      ​@@gdargdar91
      But also Pipes have async producer/consumer pattern, there is two types of pipe, `IPipeReader` and `IPipeWriter`

  • @Anllazsn
    @Anllazsn Год назад +1

    Eye opening conference, too bad the noise and claps distract it.

  • @styleisaweapon
    @styleisaweapon Год назад +7

    Its about time the working of the garbage collector is considered important instead of treated like a black box. .NET game devs take note, the GC isnt optimized for your use case, so you have to take control and do regular collection manually (GC.Collect(..) )

  • @urvhalt
    @urvhalt Год назад

    Performance and .NET in the same sentence...

    • @MarcusGarveysGhost
      @MarcusGarveysGhost Год назад +11

      I see you must have been living in a cave since the last couple .Net Core release iterations

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

      Ok then what framework would you be using to build big applications