What are record types in C# and how they ACTUALLY work

Поделиться
HTML-код
  • Опубликовано: 5 июн 2024
  • Check out my Dependency Injection course: dometrain.com/course/from-zer...
    Use discount code YTDEP2 at checkout for 15% off
    Become a Patreon and get source code access: / nickchapsas
    Hello everybody I'm Nick and in this video I will talk about the record type that was added in C# 9. Records are great and they have many usecases but in this video we are going to focus on their features and also how they made their way into the language without having to change the runtime.
    Intro - 0:00
    Record features - 1:37
    What records are behind the scenes - 10:12
    Don't forget to comment, like and subscribe :)
    Social Media:
    Follow me on GitHub: bit.ly/ChapsasGitHub
    Follow me on Twitter: bit.ly/ChapsasTwitter
    Connect on LinkedIn: bit.ly/ChapsasLinkedIn
    #csharp #dotnet #records

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

  • @ExpensivePizza
    @ExpensivePizza 2 года назад +156

    I've been coding in C# for 20 years and I still learn a lot from your RUclips channel. Thanks Nick!

    • @PaulSinnema
      @PaulSinnema 2 года назад +6

      Me too. Thanks Nick.

    • @Alequez97
      @Alequez97 2 года назад +5

      Are you that guy that bough pizza for 10k bitcoins?

    • @ExpensivePizza
      @ExpensivePizza 2 года назад +4

      @@Alequez97 Laszlo Hanyecz paid 10,000 Bitcoins in 2010 for two large pizzas. Those pizzas now only cost 0.00135 Bitcoin. I'm not the guy, but I know the story ;)

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

      Same here

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

      15 here guy here.. when I see these features I realize what all I am missing.
      Great explanation in limited time. kudos.

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

    Been writing a C# for 5+ years now but I'm still impressed how Nick knows all these syntax tricks. For example, I never used "with" keyword, seems awesome though! Not mentioning the record types itself

  • @buriedstpatrick2294
    @buriedstpatrick2294 2 года назад +21

    Records also serialize/deserialze very neatly. One issue I've had with using classes for this is the need for an empty constructor for HTTP request bodies. Essentially forcing the objects to be mutable. But with records you can have the best of both worlds. As in, enforce immutability with specific constructors while allowing for JSON serialization.

  • @AlFasGD
    @AlFasGD 2 года назад +32

    More specifically, records use the synthesis part of the lowering process. All these members are called synthesized, and it's common among the most widely adopted features of the language, including auto-properties. The compiler synthesizes those members for our convenience of not needing to write the same boilerplate code everywhere. Then, those synthesized parts are lowered into the more primitive constructs the compiler would like to care about when compiling into IL.
    Examples of other synthesized members include:
    - async/await methods (using iterators)
    - IEnumerable methods using yield (yield iterators)
    - records, as shown
    - auto-properties (using the backing field)

  • @mabakay
    @mabakay 2 года назад +3

    14:07 "From record to this monster..." Like it! ;-)

  • @responsibleparty
    @responsibleparty 2 года назад +13

    Thank you for this. I really didn't understand why record was added. Now, I see that is provided additional features but not in a more efficient way. So I would only use it if I really wanted the syntactic sugar it provides.

  • @mohamedelhakim5966
    @mohamedelhakim5966 2 года назад +1

    Really enjoyed that video

  • @barwalgayatri4655
    @barwalgayatri4655 11 месяцев назад

    One of the Best Info

  • @rikk0011
    @rikk0011 2 года назад +3

    I started using it just recently, thank for the video, this explains some of my questions!

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

    using with was amazing, you're a genius

  • @TheBdc884
    @TheBdc884 2 года назад +7

    I am a senior backend developer that has 80% or more of personal experience on Java. I have had a freelance job NetCore doing some basic projects on it and decided to take a full time job on c# and increase my knowledge. Your videos have been both very educative and surprisingly interesting and amusing! I had to thank you Nick. Happy new year! Hop you will keep on delivering this great quality content!

    • @nickchapsas
      @nickchapsas  2 года назад +2

      Happy new year! See you in 2022

  • @NameSurname-zm7gl
    @NameSurname-zm7gl 2 года назад +5

    Ok, from now number 69 is a Nick's trademark

  • @MrJeeoSoft
    @MrJeeoSoft 2 года назад +4

    I was convinced that record types were structures. Now it's more clear. Thanks for the video Nick!

    • @Krokoklemmee
      @Krokoklemmee 2 года назад

      @@Qrzychu92 that's not how structs work in C#, nick actually also has a video about that

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

      @@Krokoklemmee
      It literaly is for the most

  • @HamzaKhan-zd6qy
    @HamzaKhan-zd6qy 11 месяцев назад

    Very good and helpful.......

  • @aughey
    @aughey 2 года назад +5

    I recently resurrected an old project that was giving me grief. I upgraded the projects to the latest compiler and runtime sets, converted a lot of data code into records, and while not a silver bullet, the compiler generated capabilities of records relieved a lot of issues and code bloat.

  • @adabsurdum7011
    @adabsurdum7011 2 года назад +1

    Thank you for your content. Helps me a lot with further training.

  • @aliengarden
    @aliengarden 2 года назад

    I haven't had this much fun looking at code in a while. Sublime video!

  • @salarkazazi7584
    @salarkazazi7584 2 года назад

    One of most worthwhile channels to visit. Thank you so much.

  • @MrAndrei4777
    @MrAndrei4777 2 года назад

    Very detailed as always, thanks!

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

    I knew that there is one man on the internet who can answer my questions, so I wrote "Nick Chapsas Records" in the search bar and I didn't get disappointed ! Thank you for so many contents on so many details/subjects !

  • @infinityminuszero
    @infinityminuszero 2 года назад +1

    Dammit man! You taught so much in 15 minutes. Especially learning of sharplab was amazing for me. Thanks for your work!

  • @CeleChaudary
    @CeleChaudary 2 года назад +1

    Hi Nick, I'm from Venezuela, and one of the things for that I watch your videos is because I can totally understand you even though english isn't my native language.

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

    nice video

  • @dyrL90
    @dyrL90 2 года назад

    Great video and explanation! Thank you very much.

  • @xavier.xiques
    @xavier.xiques 2 года назад +1

    Very interesting. Thanks a lot!

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

    An excellent and lucid explanation.

  • @artursabirov8021
    @artursabirov8021 2 года назад

    Hi, Nick! I wanna thank you for your videos, when I watch it then I learn English and .Net in the same time

  • @bnotorious1
    @bnotorious1 2 года назад +1

    Nice video and explanation Nick! I noticed that this type of special class record acts like a valueObject. Can you give us an example on how to use it in a real world scenario? I will be grateful.

    • @MidnightSt
      @MidnightSt 2 года назад +1

      real world scenario?
      to represent rows in your DB ORM framework.
      or more generally, for DTOs, where they will be more comfortable to work with than normal classes.

  • @lordicemaniac
    @lordicemaniac 2 года назад +2

    can you use that $() method on any object? or is it usable only in lowered code? can anything used in lowered code be used in normal code?

    • @nickchapsas
      @nickchapsas  2 года назад +2

      Yes it is part of the ICloneable interface

  • @BEN-ys6gu
    @BEN-ys6gu 2 года назад +2

    Ok this is the kinda stuff that makes me want to learn C#. The newer versions have some really really good features.
    (I am already familiar with the language, but I want to learn more)

  • @rmdg82
    @rmdg82 2 года назад +24

    Interesting video. I'm wondering what are the ideal use cases for using record instead of simple classes. Dtos? Anything else?

    • @liveabhishekshukla
      @liveabhishekshukla 2 года назад +4

      Yes after seeing this video... I am also eager to know the use cases...

    • @nickchapsas
      @nickchapsas  2 года назад +23

      Dtos, shorthand queries or commands if you're doing CQRS with MediatR, objects that are immutable and you don't wanna bother with all the immutability implementations. The list goes on but really it is a class at the end of the day that implements what I described in the video so if you have the need for what the video showcases, then records make sense.

    • @tarekhaydar9795
      @tarekhaydar9795 2 года назад +15

      The main reason is immutability, .Net reduces the amount of work to make a class immutable by inventing Records.

    • @thiagocustodio8177
      @thiagocustodio8177 2 года назад +4

      I am so glad I am not the only one with this doubt

    • @ruekkart
      @ruekkart 2 года назад +2

      In my team we recently started using them as commands instead of classes

  • @brynarn
    @brynarn 2 года назад

    Hello Mr Nick

  • @marianvdovin2455
    @marianvdovin2455 2 дня назад +1

    so are there any reasons not to use it all the time? As I see it is a class but with extra things for free. If you don't build high performance application then I think it is the future or what?

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

    dude this is so good

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

    Is the layering on this Tuples -> Structs -> Records -> Classes?

  • @mzeeshan
    @mzeeshan 2 года назад +1

    Cool video mate!. Does that mean we can add our own custom features like Record to the C# without touching the CLR and using the lowering mechanism?

  • @TheMasterAbdul
    @TheMasterAbdul 2 года назад

    How to serialize? Or save in a table in db without any id? Would you add id fir the db?

    • @TheMasterAbdul
      @TheMasterAbdul 2 года назад

      I dont know what to ask however I am trying to say would you use it as a value object? Which in definition have no id field

  • @artemyur7162
    @artemyur7162 2 года назад

    Nice content!

  • @PaulSinnema
    @PaulSinnema 2 года назад +2

    At 3:05 Nick shows code with a 'default!' value for the property. What does the '!' do?

    • @knutharald9814
      @knutharald9814 2 года назад +3

      It prevents compiler warning about unitialized non-nullable property.

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

    dude, awesome video, thanks!

  • @EduardoAG
    @EduardoAG 2 года назад +1

    Can you use Records to serialize and deserialize json?? I mean If I change all my classes to records in my ASPNet core project it will still working?

    • @robertmrobo8954
      @robertmrobo8954 2 года назад +1

      Yes that will work. On one my projects, On the Query stack, I'm using records as my DTOs to read data from Cosmos DB. Which are serialized from Json.

    • @EduardoAG
      @EduardoAG 2 года назад +1

      @@robertmrobo8954 Nice. Thanks!

  • @CliveGregory
    @CliveGregory 2 года назад

    Any reason why the record type's ToString() method doesn't include quotation marks like JSON?

    • @nickchapsas
      @nickchapsas  2 года назад +1

      Because it isn’t json. It is just a formatted string

  • @syriuszb8611
    @syriuszb8611 2 года назад +3

    What does the syntax of .$() do? Is this something specific for lowered code? Why not just .Clone()?

    • @babafemiogundipe1453
      @babafemiogundipe1453 2 года назад

      I think there is a clone method below that create a new instance of the class

    • @syriuszb8611
      @syriuszb8611 2 года назад +2

      @@babafemiogundipe1453 I was refering to syntax, not method, what does $ mean?

    • @aliengarden
      @aliengarden 2 года назад +1

      @@syriuszb8611 I am wondering as well. Did you figure it out?

    • @Hantick
      @Hantick 2 года назад

      Wondering as well

    • @syriuszb8611
      @syriuszb8611 2 года назад

      @@aliengarden Sadly, no. My only guess is that it's specific for lowered code, I don't think that we can use it normally.

  • @metaltyphoon
    @metaltyphoon 2 года назад

    Didn’t the CLR have to change to support the idea of init ? Or was it already there because of F# ?

    • @nickchapsas
      @nickchapsas  2 года назад

      It didn't because it isn't a CLR thing, it is a complier limitation thing.

  • @barwalgayatri4655
    @barwalgayatri4655 11 месяцев назад

    Please make a Video on If Interface 8.0 can Implement methods , then do we no longer need Abstraction now ??? I know the Basic difference that Abstract cant support Multiple Inheritance but Interface ca... but then whatsss the use of Abstract then ????

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

    I am still confused thought. I get what is Record type in how it is different from Class. But what is the real use case? Where do I use Records in IRL projects, and why should I use Records instead of class? In the person example, would EF work with record type? if no then I will have to create both Person class and Person record. which is duplicaiton.

  • @jhonsondoe407
    @jhonsondoe407 2 года назад

    Hey Nick. Great video, Do you think we can use record for database entities instead of classes?

  • @KeithBarrowsToday
    @KeithBarrowsToday 2 года назад

    Way outside of the topic at hand - trying to duplicate this code line for line in VSCode - not compiling at all. Missing so many curly braces. Is this a feature of your editor?

  • @Andrew90046zero
    @Andrew90046zero 2 года назад

    What the heck is that syntax for at 15:13 where it looks like "k__BackingField" and also "$()" ?????
    I'm just curious.
    Also, I was kinda hoping you were also going to say that Records have the ability to be more effectively cleaned up by the GC. Because it seems like they are supposed to act as value types but with references. So if you create an instance of one in a function. It may be able to automatically free up the data when the function returns. So fewer allocations?

    • @nickchapsas
      @nickchapsas  2 года назад

      Records are classes (unless it’s a record struct). They don’t have fewer allocation.

    • @Andrew90046zero
      @Andrew90046zero 2 года назад

      @@nickchapsas ​ Alright cool, but what was up with that special syntax!
      k__BackingField

    • @nickchapsas
      @nickchapsas  2 года назад +1

      @@Andrew90046zero It's just how the compiler behind the scenes will generate the backing field and name it in a way that it can't clash with something that you have in your code

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

    Basically a Typed Tuple kind of thing.

  • @luan_maik
    @luan_maik 2 года назад

    Is this a good aproach to use in Value Object?

    • @nickchapsas
      @nickchapsas  2 года назад +3

      Kinda. Value objects also have some extra stuff that you need to implement to have a "true" implementation but it is a good starting point

  • @johnbleichert8322
    @johnbleichert8322 2 года назад

    Great video - thanks! Exactly what editor or development environment is that?

  • @itsquick7250
    @itsquick7250 2 года назад +1

    Whats the ! (default!) in 3:02?

  • @barmetler
    @barmetler 2 года назад +1

    How is it able to call the setter of FullName even though there isn't one? Maybe because "init" is actually a setter, and lowered code has the privilege of calling it even after initialization?
    I mean I know that lowered code doesn't have the same restrictions as normal code, but this kinda confuses me...

    • @nickchapsas
      @nickchapsas  2 года назад

      Init is basically an initialisation only setter. Properties are backed by readonly fields so even if there isn't a setter, you can still initialize a property in the constructor as if it had one, same as you would with a readonly field.

    • @barmetler
      @barmetler 2 года назад +1

      @@nickchapsas I know, but this isn't happening in the constructor. In the lowered code, it first clones the object, and _then_ overwrites all the to be modified fields.

  • @TheChlastak
    @TheChlastak 2 года назад +2

    What does this default! exclamation mark mean? 3:03

    • @XeZrunner
      @XeZrunner 2 года назад

      I would like to know that as well.

    • @lifelover69
      @lifelover69 2 года назад +2

      The exclamation mark postfix is the null-forgiving operator, introduced in C# 8.

    • @nickchapsas
      @nickchapsas  2 года назад +3

      It means, “if I dont provide the value, set this property to the not null default value for this type”

    • @vivan000
      @vivan000 2 года назад +2

      @@nickchapsas you're very wrong and `default!` should be used with huge caution.
      Default for string is null, so `default!` equals to `null!`. It initializes that string property with null, but, at the same time, asks to forgive it.
      So the only thing it's doing is removing warning (CS8618: Non-nullable property must contain a non-null value when exiting constructor. Consider declaring the property as nullable).
      You will have null in that field if you don't set it, but you've asked compiler to ignore this possibility it...

  • @oleglivcha5041
    @oleglivcha5041 2 года назад

    Great as always,thank you very much Nick!

  • @Delphi80SVK
    @Delphi80SVK 2 года назад

    Nick, can you explaing why lowering code contains "DateTime" type for "DateOfBirth" when original code contains "DateOnly" type? Is there any other underthehood magic which converts DateOnly to DateTime and vice versa?

    • @nickchapsas
      @nickchapsas  2 года назад +2

      I actually don’t know that

    • @Delphi80SVK
      @Delphi80SVK 2 года назад +1

      @@nickchapsas maybe there are operators overwritten from/to dateonly and datetime. Or bug in that website.

    • @DFPercush
      @DFPercush 2 года назад

      If I may provide a total guess, most date/time types may just be a 64 bit long containing a unix-style timestamp that gets calculated for the local date and time as needed. The DateOnly restriction probably just imposes a certain granularity on the values, like it can only be mod 24 hours or something.

  • @pagorbunov
    @pagorbunov 2 года назад

    What if the record type object has a property with a reference type? How the equality check will work? Just a references equality check?

    • @Grimlock1979
      @Grimlock1979 2 года назад +1

      It uses EqualityComparer. Default.Compare for each property. If T has not implemented any kind of equality, it will result in a reference comparison.

    • @pagorbunov
      @pagorbunov 2 года назад

      @@Grimlock1979 ty

  • @viktordoe1636
    @viktordoe1636 2 года назад +1

    "I will not buy this record; it is scratched."

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

    what is that base..ctor() in lowered code

  • @arjix8738
    @arjix8738 2 года назад

    So a record is like a data class?
    Or did I get something wrong?

  • @shanksatutube
    @shanksatutube 2 года назад

    Hey Nick, what are the contents on the C# testing course?

    • @nickchapsas
      @nickchapsas  2 года назад

      You can see the full curriculum in the course’s page

    • @shanksatutube
      @shanksatutube 2 года назад

      @@nickchapsas thanks. but looks like the YTDEP2 coupon expired. bummer :(

  • @HamishArb
    @HamishArb 2 года назад +1

    Good video! I was also hoping that you'd touch on the init keyword and modreq/modopts. Do you have one on those?

    • @nickchapsas
      @nickchapsas  2 года назад

      I am not aware of modreq/modops. I guess it’s reading time 😀

    • @HamishArb
      @HamishArb 2 года назад

      ​@@nickchapsas I look forward to the video if you make one :) they are used extensively in C++/CLI I believe (eg. const keyword on a parameter causes it)

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

      @@nickchapsas that's the answer why you know that much and willing to share. Because you learn as well, right? :) Great job Nick, I am really is amazed by quality of your videos and starting to think of making a channel myself. Reading the comments under your videos I sometimes have a lot to share but not really fan of doing it in RUclips comments :)

  • @toss2151988
    @toss2151988 2 года назад

    Hello thx for video! :) Please is Dependency Injection course also for Unity/C# developers? :)

    • @nickchapsas
      @nickchapsas  2 года назад +1

      There is a lot of focus on ASP.NET on the course but there are a lot of non-ASP.NET stuff there too.

  • @sahawndada
    @sahawndada 2 года назад +1

    How to watch a Nick Chapsas video.
    1. Smash the like
    2.Enjoy the content 👌

  • @lollo4711
    @lollo4711 2 года назад

    How do I initialize a record straight? Like:
    private record myData(string Name, int Age) = new("ABC",1);
    Couldn´t find any matching syntax to do it.

  • @clashclan4739
    @clashclan4739 2 года назад

    why Microsoft didn't mentioned about lower nowhere in its docs?

    • @nickchapsas
      @nickchapsas  2 года назад +1

      I would assume because it is an implementation detail that you don’t “need” to know about

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

    I heard they are going to rename C# 11 to F#

  • @vbaclasses3553
    @vbaclasses3553 2 года назад

    So record is the same as dataclasses in python?

    • @nickchapsas
      @nickchapsas  2 года назад +1

      Yeah, or records in Java or data classes in Kotlin or bla bla. It’s a very common feature in many languages

    • @vbaclasses3553
      @vbaclasses3553 2 года назад

      Nice that C# is also including it.

  • @logan577
    @logan577 2 года назад

    gud vid

  • @_Szakal
    @_Szakal 2 года назад

    On the line where u have "var nickbutOlder = nick with.." - as u shown when u compare nickbutOlder with nick it will say that they both not same reference, but i tried and removed 'with keyword doing "var nickbutOlder = nick" and in this case reference is the same (same as with classes) - why then with "with" it will be not same reference and without it will?

    • @nickchapsas
      @nickchapsas  2 года назад

      Because with will clone the object which creates a whole new object with a new reference

  • @programuoki-lt1465
    @programuoki-lt1465 2 года назад

    kotlin data class same as record :)

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

    10:37 mmm... sweet cheese

  • @scwyldspirit
    @scwyldspirit 2 года назад

    I was working on a WASM project type yesterday, setup the models, the DbContext and setup the DI in the Program.cs file. Then I went looking for the appsettings.json file and there is none. It is looking for deps.json file that doesn't exist either. So I created one to what it is looking for and afterwards after setting up the ConnectionString and injecting it into the SqlConnection it returns an error of Key Not Found. Try it and let me know what you think...

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

    I noticed your last part (14:30) has a datetime set to 1993, 4, 20 ? is that from a different example before the one in the beginning?

  • @AhmedAbdulla2020
    @AhmedAbdulla2020 2 года назад +1

    You know that the next video will be a perf comparison 😅

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

    If only the C# language designers created a “ref struct record class value task span” feature…

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

      The language is definitely bloated

  • @parzivallopez1272
    @parzivallopez1272 2 года назад

    came in 50 seconds. Now make a course on c# and .net core

  • @chrisfelix9065
    @chrisfelix9065 2 года назад

    This is same as data class in kotlin

    • @nickchapsas
      @nickchapsas  2 года назад

      Or data class in Python, or record in Java or

  • @pqsk
    @pqsk 2 года назад +2

    Keep coding...you say it in such a way that you're brainwashing us. I love it. 😆

  • @yasinfallah7327
    @yasinfallah7327 2 года назад

    دوست من امکانش هست که آرام تر صحبت کنی و بدون لهجه تا تمام ملیت ها متوجه بشن؟

    • @micalobia1515
      @micalobia1515 2 года назад

      His accent isn't actually very strong, for me. Personally, I think his accent actually makes him easier to understand. He could go slower though, I understand that completely, I think he goes fast so that the video isn't longer than it needs to be. It might be a good idea to change the playback speed to a lower value if that's something you can handle.

    • @nickchapsas
      @nickchapsas  2 года назад +8

      I prefer having some people slow me down than having a lot of people speed me up. I make content that I would like to watch myself and my biggest pet-peeve is slow content. I totally get how it is not for everyone but it is what most people find attractive to the channel, that I respect their intelligence and time

    • @SiOfSuBo
      @SiOfSuBo 2 года назад +3

      Omg please no
      One of the things I like about this channel is the speed.
      15 minutes to explain what would normally take hours in a classroom.
      And he is perfectly understandable, no idea what kind of accent you want him to talk with :/

    • @Hantick
      @Hantick 2 года назад

      @@SiOfSuBo Nick's accent is fine. I understand almost every word.

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

      @@nickchapsas I love your fast content :), I usually still speed it up to 1.5x (occasionally 2x). Most other similar content is 2x for me

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

    Stolen from F# like many things lol