Skip to main content

How do you give a C# Auto-Property a default value?


How do you give a C# Auto-Property a default value? I either use the constructor, or revert to the old syntax.



Using the Constructor:




class Person
{
public Person()
{
Name = "Default Name";
}
public string Name { get; set; }
}



Using normal property syntax (with a default value)




private string name = "Default Name";
public string Name
{
get
{
return name;
}
set
{
name = value;
}
}



Is there a better way?


Source: Tips4allCCNA FINAL EXAM

Comments

  1. To give auto implemented properties a default value, you'd have to do it in the constructor.

    ReplyDelete
  2. When you inline an initial value for a variable it will be done implicitly in the constructor anyway.

    I would argue that this syntax is best practice:

    class Person
    {
    public Person()
    {
    //do anything before variable assignment

    //assign initial values
    Name = "Default Name";

    //do anything after variable assignment
    }
    public string Name { get; set; }
    }


    As this gives you more clear control of the order values are assigned.

    ReplyDelete
  3. DefaultValueAttribute ONLY work in the vs designer. It will not initialize the property to that value.

    ReplyDelete
  4. Sometimes I use this, if I don't want it to be actually set and persisted in my db:

    class Person
    {
    private string _name;
    public string Name
    {
    get
    {
    return string.IsNullOrEmpty(_name) ? "Default Name" : _name;
    }

    set { _name = value; }
    }
    }


    Obviously if it's not a string then I might make the object nullable ( double?, int? ) and check if it's null, return a default, or return the value it's set to.

    Then I can make a check in my repository to see if it's my default and not persist, or make a backdoor check in to see the true status of the backing value, before saving.

    Hope that helps!

    ReplyDelete
  5. Though the intended use of the attribute is not to actually set the values of the properties, you can use reflection to always set them anyway...The unintended consequences are not clear to me at the moment (e.g. if some Microsoft coder set the meta tag incorrectly, but actually defaulted it to something else in the constructor could you override that?)

    Anyway...

    public class DefaultValuesTest
    {
    public DefaultValuesTest()
    {
    foreach (PropertyDescriptor property in TypeDescriptor.GetProperties(this))
    {
    DefaultValueAttribute myAttribute = (DefaultValueAttribute)property.Attributes[typeof(DefaultValueAttribute)];

    if (myAttribute != null)
    {
    property.SetValue(this, myAttribute.Value);
    }
    }
    }

    public void DoTest()
    {
    var db = DefaultValueBool;
    var ds = DefaultValueString;
    var di = DefaultValueInt;
    }


    [System.ComponentModel.DefaultValue(true)]
    public bool DefaultValueBool { get; set; }

    [System.ComponentModel.DefaultValue("Good")]
    public string DefaultValueString { get; set; }

    [System.ComponentModel.DefaultValue(27)]
    public int DefaultValueInt { get; set; }
    }

    ReplyDelete
  6. little complete sample:

    private bool bShowGroup ;
    [Description("Show the group table"), Category("Sea"),DefaultValue(true)]
    public bool ShowGroup
    {
    get { return bShowGroup; }
    set { bShowGroup = value; }
    }

    ReplyDelete
  7. class Person
    {
    /// Gets/sets a value indicating whether auto
    /// save of review layer is enabled or not
    [ System.ComponentModel.DefaultValue(true)]
    public bool AutoSaveReviewLayer { get; set; }
    }

    ReplyDelete
  8. Have you tried using the DefaultValueAttribute or ShouldSerialize and Reset methods in conjunction with the constructor? I feel like one of these two methods is necessary if you're making a class that might show up on the designer surface or in a property grid.

    ReplyDelete
  9. Personally, I don't see the point of making it a property at all if you're not going to do anything at all beyond the auto-property. Just leave it as a field. The encapsulation benefit for these item are just red herrings, because there's nothing behind them to encapsulate. If you ever need to change the underlying implementation you're still free to refactor them as properties without breaking any dependent code.

    Hmm... maybe this will be the subject of it's own question later

    ReplyDelete
  10. class Person
    {
    private string _name;

    [DefaultValue(true)]
    public string Name
    {
    get { return _name; }
    set { _name = value; }
    }
    }

    ReplyDelete

Post a Comment

Popular posts from this blog

Slow Android emulator

I have a 2.67 GHz Celeron processor, 1.21 GB of RAM on a x86 Windows XP Professional machine. My understanding is that the Android emulator should start fairly quickly on such a machine, but for me it does not. I have followed all instructions in setting up the IDE, SDKs, JDKs and such and have had some success in staring the emulator quickly but is very particulary. How can I, if possible, fix this problem?

CCNA 1 Final Exam 2011 latest (hot hot hot)

  Hi! I have been posted content of ccna1 final exam (latest and only question.) I will post the answer and insert image on sunday. If you care, please subscribe your email an become a first person have full test content. Subcribe now  Some question  have not content because this question have images content. So that can you wait for me? SUNDAY 1. A user sees the command prompt: Router(config-if)# . What task can be performed at this mode? Reload the device. Perform basic tests. Configure individual interfaces. Configure individual terminal lines. 2. Refer to the exhibit. Host A attempts to establish a TCP/IP session with host C. During this attempt, a frame was captured with the source MAC address 0050.7320.D632 and the destination MAC address 0030.8517.44C4. The packet inside the captured frame has an IP source address 192.168.7.5, and the destination IP address is 192.168.219.24. At which point in the network was this packet captured? leaving host A leaving ATL leaving...