Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Changing fields to property is a breaking change under what scenarios?

While reading Jon Skeet's article on fields vs properties he mentions that changing fields to properties is a breaking change.

I would like to understand the common scenarios in which this change can cause breaks. Along with the scenario, if you can, please provide any details.

For starters, the following points have been mentioned elsewhere:

  • You can't change fields to properties if you are using reflection on the class. This is obvious even though I don't have details. Serialization is one scenario where reflection is used to iterate over the object and changing fields to properties will break the serializer or change the output

  • You can't easily bind against fields. (Why is this? I read it here)

  • ???

EDIT: Robert has a comprehensive list of reasons for choosing properties over fields and also explains how switching between them can cause a breaking change.

like image 706
aleemb Avatar asked May 14 '09 12:05

aleemb


4 Answers

If you have a public field and another assembly has code that is using it, it will need to be recompiled.

IOW the definition of breaking includes "will need to be recompiled".

like image 191
Ruben Bartelink Avatar answered Nov 15 '22 10:11

Ruben Bartelink


Properties can throw any arbitrary exceptions, whereas fields can't (at least when compiler knows about field assignment at compile time).

like image 45
Valentin V Avatar answered Nov 15 '22 11:11

Valentin V


In Windows Forms at least, you can only databind things like DataGridViewColumns to properties on your business objects, not fields. So if your class was being used as a DataSource for a grid, its properties changing to fields would result in some new bugs for the grid owner.

like image 2
GWLlosa Avatar answered Nov 15 '22 11:11

GWLlosa


You can pass a field as a ref or out parameter, or take its address in an unsafe context, whilst you cannot do these with a property.

like image 1
szali Avatar answered Nov 15 '22 10:11

szali