How can I access the backing variable of an auto-implemented property?
Asked Answered
R

7

78

In the past we declared properties like this:

public class MyClass
{
    private int _age;

    public int Age
    {
          get{ return _age;  }
          set{ _age = value; }
    }
}

Now we can do:

public class MyClass
{
    public int Age {get; set;} 
}

My question is, how can I access the private variable that is created automatically using this notation?

I would rather access the private variable and not the public accessor 'Age'. Is there a default notation to access the private variable, or it is just not possible?

Rizo answered 14/9, 2008 at 17:19 Comment(2)
What is the difference in this case of accessing the private vs the public accessor? I think it is best practice to access the public accessor even from the logic in the declaring class. If you ever add some logic to the accessor you do not want to have to change all your code.Bromberg
@spoon16 Can you give me an example of adding logic to the accessor and having to change all your code as a result. I didn't really understand this part.Knar
B
92

The aim of the new automatic properties is to reduce the amount of boilerplate code you need to write when you just have a simple property that doesn't need any special logic in the get or the set.

If you want to access the private member that these properties use, that's usually for a few reasons:

  • You need to more than just a simple get/set - in this case, you should just avoid using automatic properties for this member.
  • You want to avoid the performance hit of going through the get or set and just use the member directly - in this case, I'd be surprised if there really was a performance hit. The simple get/set members are very very easy to inline, and in my (admittedly limited) testing I haven't found a difference between using the automatic properties and accessing the member directly.
  • You only want to have public read access (i.e. just a 'get') and the class write to the member directly - in this case, you can use a private set in your automatic property. i.e.

    public class MyClass
    {
        public int Age {get; private set;} 
    }

This usually covers most the reasons for wanting to directly get to the backing field used by the automatic properties.

Beige answered 14/9, 2008 at 17:47 Comment(5)
True - they do reduce bowlerplate code and I will also ad that they reduce what you need to test. Some might argue that you need to test manual get/set but not with auto properties since you can trust the framework.Dyslalia
The code sample is wrong here. It should be public class MyClass { public int Age {get; private set;} } I agree with this answer. You can't access the private field and if you need to, then you shouldn't be using Automatic Properties in the first place.Denby
hwiechers, thanks for that - I had that edit, but when trying to fix the formating I must have hit paste again and deleted the wrong block of code. Doh!Beige
Commonly used in POCO objectsRoughcast
The reason I ended up having to access the private field was because it was a struct and you can't modify a struct if it's not a variable (you'd need to create a new copy of it instead) - a private field provides a variable whereas a property (auto or not) does not.Revelation
G
23

Your usage of automatic properties implies that you do not need any getting/setting logic for the property thus a private backing variable is unneccessary.

Don't use automatic properties if you have any complex logic in your class. Just go private int _age and normal getters/setters as you normally would.

IMO, automatic properties are more suited for quickly implementing throwaway objects or temporary data capsules like:

public class TempMessage {
    public int FromID { get; set; }
    public int ToID { get; set; }
    public string Message { get; set; }
}

Where you don't need much logic.

Gerous answered 14/9, 2008 at 17:35 Comment(2)
Why would adding complex logic to your class affect whether or not you used automatic properties within that class?Bromberg
More of a consistency thing... if you have complex logic then you'll want to access it from the private backing variable per OO practices.. and if you use automatic properties then... there'll be inconsistencies in accessing those properties. since some will have underscore prefix and some will not.Gerous
Z
12

This syntax is commonly called "syntax sugar", which means that the compiler takes that syntax and translates it into something else. In your example, the compiler would generate code that looks something like this:

[CompilerGenerated]
private int <Age>k_BackingField;

public int Age
{
   [CompilerGenerated]
   get
   {
      return this.<Age>k_BackingField;
   }
   [CompilerGenerated]
   set
   {
      this.<Age>k_BackingField = value;
   }

Even knowing all of that, you could probably access the backing field directly but that sort of defeats the purpose of using automatic properties. I say probably here because you then depend on an implementation detail that could change at any point in a future release of the C# compiler.

Zenia answered 14/9, 2008 at 17:34 Comment(0)
C
10

Behind the scenes what happens is the injection of a private member variable, prefixed with <>k__AutomaticallyGeneratedPropertyField#

From C# 3.0 Automatic Properties explained

Although it may be possible to use that private member directly, it's very hacky and unnecessary.

Collin answered 14/9, 2008 at 17:27 Comment(0)
D
7

You shouldn't, and it's very unlikely you need to. If you need to access the property, just use the public property (e.g. this.Age). There's nothing special about the private field backing the public property, using it in preference to the property is just superstition.

Diphthong answered 14/9, 2008 at 20:39 Comment(2)
I always wondered what the point of automatic properties were. If you have no special logic in your getters and setters why have them at all?Dexterous
@MatthewLock flexibility. With direct field access you are locked into that design unless you change all the client code at the same time. But with a property if you decide to change it from a "pseudo-field" into a computed property, or if you decide to add assertions and checks on the setter, or what-have-you, you can do so transparently. This is even more useful if you are writing library code, where you can't control all of the client code.Diphthong
R
2

You can't, it's a language feature as opposed to a IDE feature. To be honest i'd prefer then IDE to add the private variable in for you. I agree that it is slightly weird for the class to internally have to use the public entry point to access its own variables. Hence I don't use this new feature that much myself.

Riccardo answered 14/9, 2008 at 17:22 Comment(0)
S
-1

Use C# version 13 or later :) and it will be possible.

Scilicet answered 30/5, 2024 at 12:6 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.