"Stop Using Properties in C#, Just Use Fields" | Code Cop

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

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

  • @seesharp81321
    @seesharp81321 10 месяцев назад +227

    The problem with social media these days is that negative feedback isn't visible anymore to all.

    • @SpaceTrump
      @SpaceTrump 10 месяцев назад +18

      Truth! I hate that... we need to see the negative.

    • @saedabumokh9577
      @saedabumokh9577 10 месяцев назад +9

      @@SpaceTrumpBarak Obama wouldn’t be happy about that 👨🏿

    • @LucasOliveira-sn8ls
      @LucasOliveira-sn8ls 10 месяцев назад +2

      Exactly

    • @SpaceTrump
      @SpaceTrump 10 месяцев назад +4

      @@saedabumokh9577 Ye Ol Bardock Obama can yell all he wants but I can't hear it because of my Wall.

    • @marklord7614
      @marklord7614 10 месяцев назад +7

      People get their feelings hurt when you tell them they're wrong...more now than ever in history.

  • @marcusmajarra
    @marcusmajarra 10 месяцев назад +105

    There are so many reasons why immutability can be good and that LinkedIn post managed to identify none of them.

  • @Kingside88
    @Kingside88 10 месяцев назад +32

    I didn't know about the with keyword. But it's great.
    Thank you Nick, good explanation

  • @wdolek
    @wdolek 10 месяцев назад +82

    I start to think people are exploiting this channel by sharing such ridiculous statements on LinkedIn... can't be other way.

    • @fusedqyou
      @fusedqyou 10 месяцев назад

      No, LinkedIn is in fact this ridiculous because postcount++.

    • @ErnaSolbergXXX
      @ErnaSolbergXXX 10 месяцев назад +2

      Or these advices doesnt exist in real lige?

    • @yegorandrosov6334
      @yegorandrosov6334 10 месяцев назад +1

      @@ErnaSolbergXXX they exist, i've seen many myself

    • @Zachhhx
      @Zachhhx 10 месяцев назад

      Not necessarily.. these posts happen in all programming languages

  • @tempusmagia486
    @tempusmagia486 10 месяцев назад +11

    The fact the explanation makes more sense during showing the post makes it clear that it was way too hard to explain something so obvious to someone that doesnt understand how to write c#. At the end I just feel like you try to make simple something that is already way too simple. You're a hero for trying to save people who believed that post ;(

  • @jo0ls
    @jo0ls 10 месяцев назад +1

    It’s extremely helpful to put a breakpoint in the setter to find exactly where some value is getting set. Especially with rambling legacy code.

  • @Ilix42
    @Ilix42 10 месяцев назад +43

    Imagine someone reading this and then applying it to a game in Unity or MonoGame; every time something gets hit and loses HP, you have to replace the entire object rather than just updating the HP value.

    • @RsApofis
      @RsApofis 10 месяцев назад +11

      Why to replace only some objects? Let's make the whole world immutable so we can change everything every single frame 😂

    • @Jamessik0809
      @Jamessik0809 10 месяцев назад +2

      Great example!

    • @Ilix42
      @Ilix42 10 месяцев назад +1

      @@RsApofis I can't believe I thought of HP before location or some other constantly changing stat. XD

    • @OlilittleCoUkAbout
      @OlilittleCoUkAbout 10 месяцев назад +2

      Reconstruct all the objects all the time! 😂

    • @jeffmccloud905
      @jeffmccloud905 10 месяцев назад +5

      Immutability is a concept from functional programming. it's not always the right choice in OOP

  • @petervo224
    @petervo224 10 месяцев назад +36

    I am very tempted to comment on these posts: "Congratulations! Your post has been featured in Nick's Code Cop series!"

    • @Not.Your.Business
      @Not.Your.Business 10 месяцев назад

      I see no reason not to comment that 😁

    • @petervo224
      @petervo224 10 месяцев назад

      @@Not.Your.Business there's a reason: not to get blocked.

    • @Not.Your.Business
      @Not.Your.Business 10 месяцев назад

      @@petervo224 comment from one of your throwaways ;)

    • @amirparcheko1
      @amirparcheko1 10 месяцев назад

      😂

  • @MindlessTurtle
    @MindlessTurtle 10 месяцев назад +12

    I always forget about Records in C#. I keep thinking they're useful every time I see them used, but I always forget about them when writing my own code.

  • @Eric-kx7do
    @Eric-kx7do 10 месяцев назад +20

    Yes, not using properties makes using EF harder but also WPF. It may not be the framework of the day but some of us still like and use it.

    • @doublebass120
      @doublebass120 10 месяцев назад +4

      Hello, fellow XAML enthusiast ❤

    • @7th_CAV_Trooper
      @7th_CAV_Trooper 10 месяцев назад +1

      True, these frameworks are very dated. They can't be improved now due to breaking changes.

    • @asteinerd
      @asteinerd 10 месяцев назад

      In case you might have steered away from using Records for EF; or WPF; I can tell you that the argument attribute [property: Key], [field: Index], and/or [param: RandomParameterAtrribute()] in the record's constructor/signature will allow you to have the same attribute-based class design you may already be used to.
      You already know that you're using a dated and wildly unpopular framework that, much like WinForms, is NOT going to get any more love from Microsoft in future releases.
      I would implore you to look into Electron, or at the very least Photino; which are web-based wrappers for SPA/PWAs that any well written MVVM/XAML project could be transposed into.

    • @amsalamander7521
      @amsalamander7521 10 месяцев назад +3

      ​@@asteinerd if you are talking about WPF then I can't agree with this statement. WPF is still one of the most used desktop frameworks, it is especially popular in enterprise. XAML is more pleasent experience than html + css (even with frameworks) and also offers much faster rendering.

    • @Eric-kx7do
      @Eric-kx7do 10 месяцев назад +3

      @@asteinerd i am lucky to develop for an industry that almost entirely uses Windows for console apps so cross OS support isn’t a concern. We looked into Electron and found it much too heavy. We maintain legacy apps in WPF but you are right, new applications are generally written using SPA but using Blazor. I am not a fan boy of Microsoft but if they continue to provide support it is hard for other platforms to compete.
      As an aside, like most developers I had a steep learning curve with WPF but once I got the hang of it I found the framework to be quite elegant. I never got into hardcore usage of XAML but most things could be easily done by the code behind.

  • @jongeduard
    @jongeduard 10 месяцев назад +5

    I really agree with most things you said, especially in related to those posted texts.
    But as a note I would say, the point with having immutability (by default) is make you think better about what you mutate, and express that well in code.
    The idea is not at all that you suddenly start copying everything around, because fact that's still a way of changing things, albeit while copying. But the idea is rather that what you actually want to mutate, you should also make that actually mutable, and be explicit about that.
    What I like in Rust so much, that mutability is generally not done on the level of structs and other types, but for each individual variable. Just like you can also choose to have either a reference or a direct value. And tune the lifetime of it.
    In C# this is all baked into the types itself. Reference vs value type, readonly, ref struct (which has method scope bound lifetime). This is idiomatic to the language however. So therefore I keep following that approach, and it matches here with object oriented programming and properties.

  • @XKS99
    @XKS99 10 месяцев назад +4

    Being able to blend functional and OOP concepts in an optimal way is the mark of a good C# developer.

  • @GalaktycznyPaladyn
    @GalaktycznyPaladyn 10 месяцев назад +3

    While learning OOP, I always wondered why public fields exist if they shouldn't be used

  • @Philippe42460
    @Philippe42460 10 месяцев назад +3

    I agree that every class do not have to be immutable.
    BUT if you intend to make a class IEquatable or IComparable, yes it has to be immutable, or at least properties used for comparison.
    For example, if you put instances of an IEquatable class into a HashSet so that there's no duplicate, and if you mutate a key property of one of the instances, there could then be a duplicate in the Hashset and then it is an issue.

  • @dimitris470
    @dimitris470 10 месяцев назад +4

    Yeah it's context that matters. Such advice usually refers to when ppl make everything an auto property just by sheer momentum. But yeah, instead on focusing on fields vs properties, they then talk about immutability because it's the hip thing to talk about and everything has to be about immutability and purity

  • @vladimirbodurov6572
    @vladimirbodurov6572 10 месяцев назад +1

    There is one case for the field approach. If you have large structs like Matrix or Quaternion you can pass it by reference `Method(in lssrgeStructToPass)` so to avoid creation of new struct on each method call. You cannot do that if this is a property.

  • @TECHN01200
    @TECHN01200 9 месяцев назад

    The reason why I'd avoid auto properties specifically (if I could, curse EF with its strict usage of only properties and built in json serializer for the same by default) is because then it becomes a superfluous function call in both directions. I was once asked why I pull an array's length out any time before I run a loop and it is for this very reason, every time the comparison in your loop is made, you no longer only have a comparison, but you then also have a function call of which I am unsure of if it gets optimized out.

  • @Forshen
    @Forshen 10 месяцев назад

    I love these series so much. You are so on point on everything.

  • @garcipat
    @garcipat 10 месяцев назад +1

    I think people doing such radical statements are either up for controvercy to begin with or just forget that most of the time the answer in programing is "it depends"

  • @TehGM
    @TehGM 10 месяцев назад +1

    Nick's reactions in this video are brilliant and just say it all.

    • @junior.santana
      @junior.santana 10 месяцев назад

      He was really triggered by this one 😅 (but for a reason).
      I didn't know that much about the topic and learned some things with the video, the difference between me and the OP is that I don't share tips about things I'm not sure about lol

  • @ryan-heath
    @ryan-heath 10 месяцев назад +21

    Public fields (read only if you will) are only justifiable with interop or with very high throughput demands.
    In the other 99.78% go with properties.

    • @warny1978
      @warny1978 10 месяцев назад

      For very high throughput demands, use properties with [MethodImplOptions.AggressiveInlining] attribute.
      Normaly, the JIT compiler will use it automaticaly for 4 instructions or less methods. You can enforce its use for properties, but it should not be needed unless you want to ensure high performance compilation (and you are not using reflection)

    • @mapiideal
      @mapiideal 10 месяцев назад +4

      In the case of pure properties in release mode, the JIT compiler should usually optimize the properties and use the fields directly. This means properties and fields have the same performance, the getter/setter methods are never called.

    • @brianviktor8212
      @brianviktor8212 10 месяцев назад +2

      Also count in Unity inspector elements. They also have to be public fields in order to be exposed in the inspector.

    • @7th_CAV_Trooper
      @7th_CAV_Trooper 10 месяцев назад +2

      What's your reasoning? Auto-properties give you nothing and are lowered to inline fields anyway.

    • @mapiideal
      @mapiideal 10 месяцев назад

      @@brianviktor8212 No, you can use [SerializedField] on private fields or [field: SerializedField] on properties.

  •  10 месяцев назад

    I literally have multiple structs in my library that has "public required type Thing { get; init; }" and even "public required type Thing { get; internal init; }", even better than the advice

  • @torrvic1156
    @torrvic1156 10 месяцев назад

    Hey Nick!
    Great advice about with keyword. Never knew about it. Always I learned great explanation of immutability in this video as something which can’t be changed after it has bern constructed. Thank you so much for sharing!

  • @lordmetzgermeister
    @lordmetzgermeister 10 месяцев назад

    On topic of immutable-everything, could you perhaps talk a bit about where it makes sense to use functional approaches? Maybe even interop with F#?

  • @mrshurukan
    @mrshurukan 10 месяцев назад +4

    Hello, Nick, I have a question that has been bothering me since the beginning.
    Sure, while there is an encapsulation principle, C#'s syntax to access properties and fields is absolutely the same.
    So my question is: why bother creating default { get; set; } accessors (and thus create unnecessary functions) when I can just create a public field AND THEN if I need it encapsulated (i.e. There is now some business logic like dont assign negative values) I can just add the { get => ... set => ...} and no existing code will be broken (unlike Java)
    Is it all really just because of the reflection?

    • @mk72v2oq
      @mk72v2oq 10 месяцев назад

      There is no real reason to do that. Just a code style convention pushed by Microsoft.

    • @LeMustache
      @LeMustache 10 месяцев назад

      Convention is a big reason as someone already mentioned but there are also other reasons. Just put that question into Google and you'll find a SO page that lists a lot of reasons to use auto properties rather than public fields.

    • @marcusmajarra
      @marcusmajarra 10 месяцев назад +1

      For one, properties can communicate design intent in terms of mutability control, especially as it relates to collaborators. Fields are much more limited in this respect as they can only express the mutability concern only as far as the field's initialization goes. As such, I never consider auto-property accessors and mutators to be useless because the code is more expressive as to the design intent.
      And because the compiler elides the underlying method calls as part of optimization, I can retain code that is expressive regarding the design while still enjoying the benefits performance. So I think your question should be asked in reverse: given that auto-properties don't incur a performance cost over fields, why would you want to use fields to begin with?

    • @selism
      @selism 10 месяцев назад +5

      Your existing code WILL be broken by doing that. Oh, you'll be able to compile everything again without touching the code. But if the entity with the fields and the code that calls it are in 2 different assemblies, you won't be able to replace the assembly with the entity definition with a new version that has properties without recompiling the assembly that holds the calling code.

    • @mrshurukan
      @mrshurukan 10 месяцев назад

      @@selism this one actually resonates a lot with me, dont get me wrong, the other comments all bring important points to the table, but yours is actually revealing a contradiction in my own
      Thanks!

  • @jfftck
    @jfftck 10 месяцев назад +1

    I would love C# to have a default of immutable variables/fields/properties and require a mutate keyword, but it could be a modifier for namespace or project configuration value. It is better to specify mutability than to apply read only using readonly or init keywords. I find that setting to read only can be missed, but trying to mutate something that is immutable would fail and make you mark it as mutable to use it.

  • @AntiPolarity
    @AntiPolarity 10 месяцев назад +1

    Still don't understand why you can't use fields instead of get-set properties? Fields are faster and you can add get-set any time is you need it later

  • @pokefreak2112
    @pokefreak2112 10 месяцев назад +6

    I actually agree with his advice in general, but not for the reasons he listed lol
    What I like about properties is that you don't need to premeditativly add getters and setters. You can just start with a field and refactor into a property when you need some logic without breaking your public API.
    Starting with a { get; set; } property makes no sense, you're adding a layer of indirection for no reason.

    • @Kwpolska
      @Kwpolska 10 месяцев назад +2

      Adding `{get;set;}` does not break the API, but it does break the ABI, requiring recompilation of code that uses your thing as a library. In C#, {get;set;} aren’t that bad, I would agree that getters and settesr are cargo cult in Java. (And also, how often do people really end up adding logic to a property in the future?)

    • @pokefreak2112
      @pokefreak2112 10 месяцев назад

      ​@@Kwpolska Didn't think about that, thanks for mentioning it! I mostly know C# from a gamedev perspective where it's not a big deal to just recompile when updating dependencies, but I can imagine it's nice to be able to swap out a DLL in live environments without needing to recompile/restart the entire system.

  • @beetrootpaul
    @beetrootpaul 10 месяцев назад +2

    Putting special cases aside: in particular, what is the major advantage of using getters and setters instead of a direct access to a field? I mean, if in the end the access it the same, you can read and modify a thing from anywhere outside

    • @ErnaSolbergXXX
      @ErnaSolbergXXX 10 месяцев назад +3

      With complex/messy code one big benefit is you are able to set breakpoints on setters and getters

    • @mk72v2oq
      @mk72v2oq 10 месяцев назад +3

      There are no real advantages. In fact, if you have autoproperties without extra code, JIT optimizer is smart enough to simply throw off intermediate calls and use direct field access anyway.

    • @7th_CAV_Trooper
      @7th_CAV_Trooper 10 месяцев назад +2

      ​@@ErnaSolbergXXXwell, if you were writing immutable objects you wouldn't need those breakpoints.

    • @beetrootpaul
      @beetrootpaul 10 месяцев назад +2

      Thanks for answers so far. I will share a bit of a context for my question: years ago I was working with Java and getters/setters vs fields was definitely a subject of heated discussions. And sometimes it sounded like “you have to do it this way, because this is The Only Clean Way” without really justifying it.
      Nowadays, after several years in JS/TS I sometimes wonder how vastly different approaches can be across languages and their communities. And, in the end, kinda everyone creates a software that works and has its better and worse time when maintaining it. And when I see a big value in having TypeScript instead of JavaScript when it comes to evolving a large codebase, I at the same time do not believe props/fields argument has any real significance (unless working with things that enriches the code somehow and expects props or working with public APIs and necessity to not break them while having to adjust our code etc, I assume)

    • @PedroPabloCalvoMorcillo
      @PedroPabloCalvoMorcillo 10 месяцев назад +1

      Perhaps open / closed principle is better accomplished with properties than with sheer fields.

  • @DevDunkStudio
    @DevDunkStudio 10 месяцев назад +1

    I heard the opposite one time.
    Use properties for everything, that way you can see the amount of references above the line in Visual Studio

  • @Daniel15au
    @Daniel15au 10 месяцев назад

    C# also has record structs now, for stack-allocated immutable records :)

  • @AlgoristHQ
    @AlgoristHQ 10 месяцев назад

    I always thought you use properties for things you intend to serialize and fields for things you don't. I totally accept if Im wrong on that!

  • @AK-vx4dy
    @AK-vx4dy 10 месяцев назад

    In past years it was taught that is recomended and idiomatic to expose public as properties for future compatibilty reasons.

  • @maxparker4808
    @maxparker4808 10 месяцев назад

    They seem to have misunderstood what immutability is for.
    The real benefit is in having a crystal clear API. That is, if you return something with properties with get/set all over the place, the implication is that if you change it that it changes… but this is rarely the case. Sure, that value on that instance might change in memory, but it’s done nothing to persisted state unless this has been implemented internally within the class (which is almost never the case in reality).
    Immutable properties makes it clear to the consumer that you can’t do this. It’s self-documenting.
    Nailed it with get; init; -> much clearer and doesn’t require a verbose constructor, AND it’s fully compatible with JSON serializers.

  • @muemmel20
    @muemmel20 10 месяцев назад +3

    I agree with most of this, but I still haven't heard any good argument for 'naked' auto-properties as a principle. Changing the approach would probably not be of much use because of conventions. I just hate having conventions that are there for no good reason. I have yet to hear a good one from anyone that isn't circular (i.e. you should use the convention, because the convention is expected). I try to avoid setters and would rather use explicit Set methods, but I got to the point where I rarely use properties, even though I declared them. So they effectively become readonly fields to the outside. Getters and setters (and especially init setters) are great for dumb/data classes, for anything else I don't find them all that useful.

    • @sealsharp
      @sealsharp 10 месяцев назад

      The name "property" is very intentional. It communicates that it is something about the state of the instance. Methods are what the instance does.
      The syntax of using properties is similar to accessing fields, because that's what it is supposed to represent, accessing something with additional encapsulation and the ability to add behavior and sanitization.
      There's a third, which is indexers, which are technically just methods as well but are build to look like accessing an array-like indexed data structure.
      We could just as well write methods, but we could also write an indexer that has nothing to do with accessing any index if we feel like it. Probably not the best way to communicate what's actually done.

  • @laiserfire
    @laiserfire 10 месяцев назад

    I would expect fields to be faster as they do not require a methode call to access the backing field. Does someone have a benchmark on this?

    • @Briezar
      @Briezar 10 месяцев назад

      unless you do some validation on the getter, the performance diff is virtually non-existant. Even a billion read call to a property won't make it slower than 5% vs fields, or 0.2 ns diff (till.red/b/1)

  • @drndn
    @drndn 10 месяцев назад

    Making objects immutable IS what you want the vast majority of the time, and it is only relatively rare cases where having them be mutable makes more sense. Database records like this "User" are an example where immutable is better. While it is true that copying all the fields when you want to fake updating a User is slower, you have to keep in mind that the times when you'd legitimately want to do that are very rare, so the fact it is a bit slower isn't a problem in practice, because you don't do that often, and meanwhile the immutable is optimized for the much more common scenario where you DON"T want to update the object.

  • @slowjocrow6451
    @slowjocrow6451 10 месяцев назад

    @9.00 that record won't have required fields right? does that matter? Is it possible to add the required keyword for a records?

    • @SnOrfus
      @SnOrfus 9 месяцев назад

      They will be required, yes.

  • @Bliss467
    @Bliss467 10 месяцев назад

    For webservices, DAOs are the only classes where mutability makes any sense. I wish c# were an immutable by default language with opt-in mutability like rust.

  • @Swerik
    @Swerik 10 месяцев назад +5

    Even their example is broken.
    They say If you have the User with the FirstName John, why should you want to change the name to Mark? It's obviously a different Person, so it needs to be a new Object.
    What is with the surname? That can change when someone marries for example, is that not the same person then?

    • @Kwpolska
      @Kwpolska 10 месяцев назад +2

      It is legal in most places for a person to change their first name at some point in their life. It’s less common than changing last name at marriage, but it does happen.

  • @GigaFro
    @GigaFro 10 месяцев назад

    Do you have a submission form for eyebrow raising posts? I came across some for Typescript this past weekend on X and I can't stop *face palming* from it and seeing how exuberant everybody was about the post. Keep laying down your justice Nick! It is giving us hope :)

  • @unityasteroids1562
    @unityasteroids1562 10 месяцев назад

    You've got my like, there is so much garbage advice on linkedin that its almost comical

  • @Lactorioga
    @Lactorioga 10 месяцев назад

    What about property performance - are getters-calling have no effect in terms of speed? May be this have some impact, that make it reasonable to eliminate props on super high load systems?

    • @janovrom
      @janovrom 10 месяцев назад

      It does increase performance. Setting a property or setting a field does make a difference. But we are talking a game loop with tens of thousands of such calls.
      Edit: Though last benchmarked on net core 3.1...so ages ago.

    • @Briezar
      @Briezar 10 месяцев назад +1

      unless you do some validation on the getter, the performance diff is virtually non-existant. Even a billion read call to a property won't make it slower than 5% vs fields, or 0.2 ns diff (till.red/b/1). It's not wise to sacrifice future-proof for a measle increase in performance.

    • @Lactorioga
      @Lactorioga 10 месяцев назад

      @Briezar Who ever do getter setter validation in 99.99% cases))

    • @janovrom
      @janovrom 10 месяцев назад

      @@BriezarSo just to be sure, I made benchmarks for it on sdk 8.0.200 and 6.0.411. For pure setter, it makes no difference. But doing a sum of property on an object and a sum of field on an object is 30us difference for 100k objects on sdk 6, but 8 on sdk 8. For 1mil objects, it makes a difference in context of 16 ms per frame, but not on a new sdk version. I've ran the tests multiple times and they were not consistent, so if you were to even consider this change, benchmark it.Edit: I did some more tests where you wrap multiple properties (time, speed, offset, and readonly property to get distance). For 1mil objects, it's 0.5 ms but it's optimized in net 8.

  • @cabriolex
    @cabriolex 10 месяцев назад

    There is just one huge problem with c# records: "with" statement has limited mutation scope with assignments only, what makes complex assignments (partial, conditional, switch assignments or mutation methods) impossible or difficult. Almost unusable IRL.
    Having readonly fields allows you to define specialised constructor, where you can assign all fields however you like.
    Not to mention that field access time is always faster and easier for JIT/AOT to read/write, because sometimes its inlining logic is just umfathomable.
    Do you have a video with fields/properties access performance benchmarks for real life scenarios?
    Reflection-based access to fields/properties is almost the same. I don't get why EF/XAML/Blazor stuff cannot read/write fields the same way they do with properties. Even readonly fields could be assigned if needed.
    Fields need less typing and can be multiply declared. (public string Name, Surname, Email;)
    Fields can also have visibility modifiers (public, private etc.), can be agumented with attributes, so what's an added value of being a property, if there is no computation in getter and no special logic in setter?

  • @Azzarrel
    @Azzarrel 10 месяцев назад

    OOP has been created in order to re-create real-life scenarios in a program. Just imagine a real life scenario with an employee. "Oh, sorry. I noticed you misspelled me 'Jhon' in my company account". "Oh gosh dang it. Please can I have back your company ID card, your company laptop and ... could you submit your application again. Yea i know what you wanna ask. I can't just change the name, I have to create a fully new user. Each user also get's a new ID card and laptop. Don't ask. By the way ... your wage is readonly too, so be we're gonna meet again next year."

  • @abhaynath5833
    @abhaynath5833 10 месяцев назад

    Mutability is great if the application is inherently functional in its nature. Like compilers, cli tools or data processors.
    Games and other GUI applications need to maintain states. Creating new object everytime for a small change is very expensive.
    Imagine creating a new player object 60 times per second just to change x,y position of character on screen.

    • @diadetediotedio6918
      @diadetediotedio6918 10 месяцев назад

      Take a look on the ECS architecture, you will see how this could also work at least partially.

  • @bslushynskyi
    @bslushynskyi 10 месяцев назад

    WPF is not going to work properly with fields, because framework assumes interaction with user-defined data through properties.

  • @arztje
    @arztje 10 месяцев назад +1

    Yeah, I gave this author crap for this on Linked-In for garbage posting. This guy proved he doesn't understand properties, immutability, proper naming, when to use constructors, etc. Nick's video is spot-on as always.

  • @drndn
    @drndn 10 месяцев назад

    Also, having undateable database records is also a bad practice in the most common cases. The vast majority of the time, database tables should be insert-only, representing events that are immutable rather than mutable entities.

  • @patfre
    @patfre 10 месяцев назад

    I think the bigger reason they say to use it is performance. Properties are slower than fields as properties are like a method call while a field directly accesses the object/value it contains

    • @Briezar
      @Briezar 10 месяцев назад

      unless you do some validation on the getter, the performance diff is virtually non-existant. Even a billion read call to a property won't make it slower than 5% vs fields, or 0.2 ns diff (till.red/b/1). It just smells premature optimization, and not even a good one.

    • @gnack420
      @gnack420 10 месяцев назад

      You're asserting here that there's a performance cost for auto properties, do you have benchmarks that show this? My understanding is that the compiler elides that "method call" away.

    • @lordmetzgermeister
      @lordmetzgermeister 10 месяцев назад +2

      If one method call is a tragic performance loss then C# was a bad choice of technology in the first place.

    • @patfre
      @patfre 10 месяцев назад

      I am not saying I agree it’s a proper reason because it’s not and as people has said it’s virtually non existent but I have seen multiple people say “well if properties are slower why the f*** would you rather use them?” Which is why I mentioned this as this is the most common reason I have seen

    • @patfre
      @patfre 10 месяцев назад

      @@gnack420 it does not do this as he showed a property is converted to a field with a getter and a setter of which both are methods in the way they are executed so it does not abstract it away but rather is just syntactic sugar

  • @WilliamCWayne
    @WilliamCWayne 10 месяцев назад

    Obviously, if you can't change a class, you can't maintain it. Therefore, the maintainability metric is maxed out!

  • @parlor3115
    @parlor3115 10 месяцев назад

    Yeah, I don't like properties either. They're an invitation to put logic in the getters or setters. Classes can either model services (controllers, db clients, api clients, ...), or data. You don't need properties for either unless you're refactoring a legacy codebase and need to maintain a stable API. If you're starting a new projects, then you're better off imposing on yourself to just use constructor-initialized fields.

  • @TheAceInfinity
    @TheAceInfinity 10 месяцев назад

    They definitely didn't understand get-only properties that you can initialize from the constructor or required readonly get/init. I've been trying to explain how bad LinkedIn is for programming advice for years haha.

  • @pedromota987
    @pedromota987 10 месяцев назад

    I like these videos about LinkedIn posts

  • @keletsoa.botsalano4531
    @keletsoa.botsalano4531 10 месяцев назад +1

    “The only (buzz) word missing here is clean” 💀💀💀

  • @Rolan18111
    @Rolan18111 10 месяцев назад

    Sounds like the OP was implicitly trying to create an event sourcing application - then forgot to mention the architecture

  • @billy65bob
    @billy65bob 10 месяцев назад +1

    Honestly, I still think properties are lame the majority of the time because nothing beyond setting/retrieving the value is abstracted (and with some languages, at significant performance cost outside of release builds)
    I kind of just tolerate it because .NET (unlike Java and many others) takes all the boilerplate out by making it as easy as Type Name {get; set;}, so I have no real reason to be obstinate about it.

  • @mykola2
    @mykola2 10 месяцев назад +4

    So, with all those bad advises, has LinkedIn became TikTok?

  • @asteinerd
    @asteinerd 10 месяцев назад +1

    We're getting close folks LOL!
    My new favorite clip of Nick; ruclips.net/user/clipUgkxxq_NLg3b0eMkCmws0B2EY079YuYms61w?si=bkH_WfMEFzLGa4kO
    We're just missing two more words and a camera slap.
    I'm sure the code-cop series will lead to this. 😝

  • @dandandan01
    @dandandan01 10 месяцев назад +2

    2:23 - i feel you did that a bit too hard to yourself 😂

  • @tunawithmayo
    @tunawithmayo 10 месяцев назад +2

    This advice is obviously coming from a Functional Programing enthusiast. The techniques used for Functional programing don't make sense if you are thinking about things from an O-O perspective, which of course they don't, because its two totally different programming styles.

  • @rik2243
    @rik2243 10 месяцев назад

    At the risk of being unpopular, I think Properties are a bad thing, they just add confusion, by mixing up processing and storing values. You have methods for processing and fields/variables for storing values, allowing processing in two places just makes things harder to understand.
    Imagine a new developer trying to understand all the subtle differences with all the different property options: (internal, public, private, static, readonly, const, virtual, abstract, required, private set, init). In the end you just want to set a variable for internal or external use. There is no need for this level of subtlety. If you wanted to simplify C# (which I think is desperately needed) removing properties would be a good starting point, IMO.
    Would it really be so hard to just to use Private and Public fields and that’s it?

    • @BigBang1112tm
      @BigBang1112tm 9 месяцев назад

      For day to day cases, properties can configure the restrictions of what you can do with variables inside and outside the class, like if outside is able to set it, while still retrieve it, or not. You cannot do this with fields alone.
      I'm not a huge fan of the bloat properties give, but it works better for bigger enterprise software (or something else serious is other form) than fields.
      For example, when consumer expects value in one format you give them originally, but you want to change how that value is handled inside the class, you can turn the auto property into full property and adjust this behaviour, without introducing a breaking change. Or you can add subtle behaviour to trigger on get/set, without having to tell user to switch from using field to a method, or validation purposes (but I'd prefer compile-time solutions there). Later on in the development these requirements might come in.
      The learning curve of properties is just not that good and never has been, many teachers either skip or repeat the same confusing theory.

  • @nickcorrado5105
    @nickcorrado5105 10 месяцев назад

    I feel like for Nick's blood pressure LinkedIn needs a way to signal *dis*approval of these posts. 250 people think this bad advice is great, but how many shook their heads and scrolled on?

  • @homosuperior1337
    @homosuperior1337 10 месяцев назад

    Code Cop don't take us properties. They are such a great reminder to good old delphi and object pascal. 😊

  • @ВладКалашников-м8п
    @ВладКалашников-м8п 10 месяцев назад

    The text of this LinkedIn post looks more like it was AI-hallucinated than written by an actual developer 😂

  • @josephmoreno9733
    @josephmoreno9733 10 месяцев назад +1

    Expose fields is dangerous cause c# can address directly a reference to it.
    That is only useful in some situations, but only in these situations.
    By convention, the only public fields that I do expose as public are the static readonly one.

    • @diadetediotedio6918
      @diadetediotedio6918 10 месяцев назад

      Why exactly this is "dangerous"?

    • @josephmoreno9733
      @josephmoreno9733 10 месяцев назад

      @@diadetediotedio6918
      The reason for encapsulation is to not allow, not only the access (obtaining) of the class information but, even more so, the unauthorized modification of information.
      Unlike Java, in .NET it is possible to obtain a managed reference of a field, which could modify a 'final' field.
      That is useful and powerful, but dangerous. Please check the following code:
      using System;
      using System.Runtime.CompilerServices;
      public class Program
      {
      public static void Main()
      {
      PublicClassField obj = new("Text0");
      ref String refField = ref Unsafe.AsRef(in obj.PublicField);
      Console.WriteLine(obj.PublicField);
      refField = "text1";
      Console.WriteLine(obj.PublicField);
      }
      public class PublicClassField(in string value) {
      public readonly String PublicField = value;
      }
      }

    • @josephmoreno9733
      @josephmoreno9733 10 месяцев назад

      @@diadetediotedio6918
      The reason for encapsulation is to not allow, not only the access (obtaining) of the class information but, even more so, the unauthorized modification of information.
      Unlike Java, in .NET it is possible to obtain a managed reference of a field, which could modify a 'final' field.
      Check this code.
      using System;
      using System.Runtime.CompilerServices;
      public class Program
      {
      public static void Main()
      {
      PublicClassField obj = new("Text0");
      ref String refField = ref Unsafe.AsRef(in obj.PublicField);
      Console.WriteLine(obj.PublicField);
      refField = "text1";
      Console.WriteLine(obj.PublicField);
      }
      public class PublicClassField(in string value) {
      public readonly String PublicField = value;
      }
      }

  • @cholling1
    @cholling1 10 месяцев назад

    Know who else hated mutability? Colonel William Stryker.

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

    Even if the advice about immutability was good, they missed giving you good advice about even that. They should have said use "record" instead of class for everything...

  • @andreasmewald2439
    @andreasmewald2439 10 месяцев назад +3

    At the end FP, OOP, immutability, mutability, ... are tools that you can use to solve a given problem. There is no in general this is better than that.

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

    Immutable is good. If you're using readonly auto properties, why not use fields. Constructor is absolutely the right way to set fields. Should not be possible to create incomplete object. Record doesn't work because you can't protect the object from invalid initialization.

    • @PedroPabloCalvoMorcillo
      @PedroPabloCalvoMorcillo 10 месяцев назад +1

      I think records do prevent invalid initialization as well as required init fields.

    • @7th_CAV_Trooper
      @7th_CAV_Trooper 10 месяцев назад +1

      @@PedroPabloCalvoMorcillo show me how to perform null checks.

    • @PedroPabloCalvoMorcillo
      @PedroPabloCalvoMorcillo 10 месяцев назад

      @@7th_CAV_Trooper Fair enough. Even with Nullability checks activated, external dependencies could initialize fields as null. Having said that, for your own application records are OK.

  • @andreaskarz
    @andreaskarz 10 месяцев назад

    What??? 🤣🤣best parts of the video 😛

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

    well well, the records are bloated data structures. fields are the slimest but they are not well supported by the .net framework. so yeah, there is a point there, but it won't work. :)

  • @figloalds
    @figloalds 10 месяцев назад +3

    I think functional bros space out too much sometimes.

    • @7th_CAV_Trooper
      @7th_CAV_Trooper 10 месяцев назад +1

      Embrace the funk, man. Embrace the funk.

  • @LowPolyPixel
    @LowPolyPixel 10 месяцев назад

    The reason you use fields instead of properties is to mess up the training data of LLMs

  • @mattbristo6933
    @mattbristo6933 10 месяцев назад

    There is no one size fits all.

  • @ThekillingGoku
    @ThekillingGoku 10 месяцев назад

    Let's all just start throwing naming conventions out the window too. Wether or not you're a '_field' or 'field' type of guy, it's generally accepted that 'Property' is the naming convention.
    Now you're just confusing any and all implementors of your code (just imagine this actually making its way into some kind of library you implement). Do you expect everybody to decompile your library to figure out where you're messing with us by exposing fields using property naming conventions???
    Anyway, the whole thing is a mess and I see very little purpose and/or advantages to it. This person just doesn't get OOP, trying to turn it into something it's not.
    Just imagine WPF/XAML w/o binding?!? No doubt MVC model binding would bomb on this too, since it can't map that object. Just imagine X, Y & Z. This is just plain bad.

  • @michielschaeverbeke1421
    @michielschaeverbeke1421 10 месяцев назад

    I find it painful to see that the argument "object construction should be used sparingly because it is time-consuming" is still used. Unless you are dealing with millions of objects being constructed the creation time is negligible, so please stop using this excuse. Your machine has at least 8 cores each performing bilions of operations per second so stop it already.
    Furthermore I agree that you shouldn't make all classes immutable but it is an underused feature. In the example of changing the name I agree to make it immutable because it's part of the identity of the object. John isn't Mark. Any other object that has a reference to it might run in trouble because now suddenly someone out there thought it necessary to change the value of an identity field. And now Mark owns John's car, congratulations, who's going to pay for the damage to John? You?

  • @Rajeshsingh-ws5th
    @Rajeshsingh-ws5th 10 месяцев назад

    Hey Nick, some back your vid (ruclips.net/video/QdfAOVk77v0/видео.html ) don't use fields use properties and now this? Anything changed in C#?

    • @nickchapsas
      @nickchapsas  10 месяцев назад

      They are both bad advice

  • @anantmishra6783
    @anantmishra6783 10 месяцев назад

    had some devs like this in my team, who confidently threw these words senselessly, and manager couldn't differentiate between their nonsense and truth, ended up with massive fack ups!! These are the same people who write these kind of trashy things on linkedin ... 👍🏻

  • @gautambhatnagar4765
    @gautambhatnagar4765 10 месяцев назад

    Feels like generative ai wrote the original post

  • @Silentsouls
    @Silentsouls 10 месяцев назад

    John cannot age in an immutable object.

  • @omkelderman
    @omkelderman 10 месяцев назад +11

    I have a feeling this person just hates OOP lol

    • @7th_CAV_Trooper
      @7th_CAV_Trooper 10 месяцев назад +1

      Or they hate debugging code. Immutable objects is the right answer most of the time. Not all the time, but most.

    • @F1nalspace
      @F1nalspace 10 месяцев назад

      @@7th_CAV_Trooper
      I dont like OOP very much, even though i write it every day - but i can live it and understand it. I even agree with nick this time. Also the compiler is smart enough to not generate a second backing field, if you already use one.
      For example: ImmutableArray without initialization breaks your application on access.
      So to fix that, i have a field that is always initialized to Empty and is modified/returned in the property only.
      I dont understand why MS introduced that feature, using a struct that breaks on read when you dont initialize/set it.

    • @diadetediotedio6918
      @diadetediotedio6918 10 месяцев назад

      @@F1nalspace
      The reason is for you to not needing to necessarily allocate every time you modify it, using structs is cheaper this way. I think the problem is microsoft not treating an uninitialized ImmutableArray as 'Empty' by default.

  • @WDGKuurama
    @WDGKuurama 10 месяцев назад +2

    They should add dislikes to LinkedIn ngl

  • @Vityhard
    @Vityhard 10 месяцев назад

    Please show the authors, I'd like to block people like this :)

  • @badger2-383
    @badger2-383 10 месяцев назад

    You know how people will learn how to do something, then create "how to" videos or guides on it? As if they're an expert - but they're just doing it to reinforce their learning.... that's what that LinkedIn post smells like.

    • @jsm33t
      @jsm33t 10 месяцев назад

      true!!! I remember seeing people posting about learning javascript and now after a span of a few months they are posting "how to" with words that seems like GPT generated

  • @mysteriouse5891
    @mysteriouse5891 10 месяцев назад

    "Please use Hungarian Notation."

  • @jantajov
    @jantajov 10 месяцев назад

    Some of these "advices" are so ridiculous they need no debunking.

  • @MJSmithGroup
    @MJSmithGroup 10 месяцев назад +1

    100% that article was AI generated.

  • @Vayku
    @Vayku 10 месяцев назад

    At this point they are just baiting to be on code cop. Can't make this up

  • @Kimo.Codess
    @Kimo.Codess 10 месяцев назад

    Some haskell dev using C#

  • @PSHomeVideo
    @PSHomeVideo 10 месяцев назад

    Instead of doing useful work, developers nowadays pay too much attention to imaginary best practices, many of which become just a kind of religious cults with negative value

  • @nolios.
    @nolios. 10 месяцев назад +2

    I'm first for once?

    • @nickchapsas
      @nickchapsas  10 месяцев назад +43

      OrDefault

    • @ryanzwe
      @ryanzwe 10 месяцев назад +2

      Lol

    • @Briezar
      @Briezar 10 месяцев назад

      you're null

    • @johnnyblue4799
      @johnnyblue4799 10 месяцев назад +12

      @@nickchapsas Did you just suggest he might be null? 🤣

    • @nolios.
      @nolios. 10 месяцев назад +2

      ​@@nickchapsas 😂😂 Love your videos, keep up the great content!

  • @viktoralferov2874
    @viktoralferov2874 10 месяцев назад

    Idiocracy

  • @MaximilienNoal
    @MaximilienNoal 10 месяцев назад +1

    Yeah this advice is for Java people. No thanks.

  • @anonimzwx
    @anonimzwx 10 месяцев назад

    really, who do this kind of advise? they are terrible advises

  • @kristofbe1
    @kristofbe1 10 месяцев назад

    This post seemed like it was AI generated

  • @B1aQQ
    @B1aQQ 10 месяцев назад

    That is probably the worst advice in Code Cop so far. Took me 1 second to think "init".

  • @someguyO2W
    @someguyO2W 10 месяцев назад

    It's sad how bad this video actually is.

  • @evihofkens9530
    @evihofkens9530 10 месяцев назад +1

    LinkedIn needs a dislike button.

  • @RobertPaulsim
    @RobertPaulsim 9 месяцев назад

    jesus