Single height = 5;
double volume = Math.PI * Math.Pow(radius, 2) * height;
If you exclude the variables declaration in the refactoring (instead of selecting all the three lines; see Figure 2-49) and name the new method VolumeofCylinder
, a method with two parameters is created:
private void Form1_Load(object sender, EventArgs e) {
Single radius = 3.5f;
Single height = 5;
}
data:image/s3,"s3://crabby-images/a0a0c/a0a0cc0f42cb3611de300757336b8dd2bb558b75" alt=""
Figure 2-49
Here are some observations:
□ Variables that are defined outside of the highlighted block for refactoring are used as an input parameter in the new method.
□ If variables are declared within the block selected for refactoring, the new method will have no signature.
□ Values that are changed within the block of highlighted code will be passed into the new method by reference.
You can use code refactoring to reorder the parameters in a function. Consider the following function from the previous example:
private static double VolumeofCylinder(Single radius, Single height) {
return Math.PI * Math.Pow(radius, 2) * height;
}
Highlight the function signature, right-click it, and select Refactor→Reorder Parameters (see Figure 2-50).
data:image/s3,"s3://crabby-images/3b763/3b76327241606b377c7a6c8b316cf22e47738dfa" alt=""
Figure 2-50
You can then rearrange the order of the parameter list (see Figure 2-51).
data:image/s3,"s3://crabby-images/4c024/4c0246cb3a0e17eacaa23682828153010f0eb858" alt=""
Figure 2-51
Click OK. You can preview the changes before they are made (see Figure 2-52).
data:image/s3,"s3://crabby-images/ef04b/ef04bd17ab0c8fde72c783636fac773db1aa4598" alt=""
Figure 2-52
Once you click the Apply button, your code is changed automatically:
private void Form1_Load(object sender, EventArgs e) {
Single radius = 3.5f;
Single height = 5;
}
return Math.PI * Math.Pow(radius, 2) * height;
}
All statements that call the modified function will have their arguments order changed automatically.
You can also remove parameters from a function by highlighting the function signature, right-clicking, and selecting Refactor→Remove Parameters. Then remove the parameter(s) you want to delete (see Figure 2- 53). All statements that call the modified function will have their calls changed automatically.
data:image/s3,"s3://crabby-images/e52de/e52deaaafb8617c29849e835742f047772373c68" alt=""
Figure 2-53
Consider the following string declaration:
namespace WindowsFormsApplication1 {
public partial class Form1 : Form {
private void Form1_Load(object sender, EventArgs e) {
//...
}
}
}
Instead of exposing the caption
variable as public, it is a better idea to encapsulate it as a property and use the set
and get
accessors to access it. To do that, right-click on the caption variable and select Refactor→Encapsulate Field (see Figure 2-54).
data:image/s3,"s3://crabby-images/4137c/4137c62c1204c751e75c46f1a6b1f13177d19781" alt=""
Figure 2-54
Assign a name to your property (see Figure 2-55). You have the option to update all external references or all references (including the one within the class), and you can choose to preview your reference changes. When you're ready, click OK.
data:image/s3,"s3://crabby-images/f83ba/f83ba0ba252f1f57bc1644dd33393eeb06712218" alt=""
Figure 2-55
After you've previewed the changes (see Figure 2-56), click Apply to effect the change.
data:image/s3,"s3://crabby-images/54892/54892fbd8acbcc4efb1ec9f4502406f2ca4ff059" alt=""
Figure 2-56
Here is the result after applying the change:
namespace WindowsFormsApplication1 {
public partial class Form1 : Form {
private void Form1_Load(object sender, EventArgs e) {
//...
}
}
}
You can use the refactoring engine to extract an interface from a class definition. Consider the following Contact
class:
namespace WindowsFormsApplication1 {