disable broken tests on net_4_0
[mcs.git] / docs / ecma334 / 8.7.4.xml
blob0a200a01abc630b31f19d787e87193b6c2856ddd
1 <?xml version="1.0"?>
2 <clause number="8.7.4" title="Properties" informative="true">
3   <paragraph>A property is a member that provides access to a characteristic of an object or a class. Examples of properties include the length of a string, the size of a font, the caption of a window, the name of a customer, and so on. Properties are a natural extension of fields. Both are named members with associated types, and the syntax for accessing fields and properties is the same. However, unlike fields, properties do not denote storage locations. Instead, properties have accessors that specify the statements to be executed when their values are read or written. </paragraph>
4   <paragraph>Properties are defined with property declarations. The first part of a property declaration looks quite similar to a field declaration. The second part includes a get accessor and/or a set accessor. In the example below, the Button class defines a Caption property. <code_example><![CDATA[
5 public class Button   
6 {  
7    private string caption;  
8    public string Caption {  
9       get {  
10          return caption;  
11       }  
12       set {  
13          caption = value;  
14          Repaint();  
15       }  
16    }  
17 }  
18 ]]></code_example></paragraph>
19   <paragraph>Properties that can be both read and written, such as Caption, include both get and set accessors. The get accessor is called when the property's value is read; the set accessor is called when the property's value is written. In a set accessor, the new value for the property is made available via an implicit parameter named value. </paragraph>
20   <paragraph>The declaration of properties is relatively straightforward, but the real value of properties is seen when they are used. For example, the Caption property can be read and written in the same way that fields can be read and written: <code_example><![CDATA[
21 Button b = new Button();  
22 b.Caption = "ABC";    // set; causes repaint  
23 string s = b.Caption;  // get  
24 b.Caption += "DEF";    // get & set; causes repaint  
25 ]]></code_example></paragraph>
26 </clause>