Best way to expose protected fields

前端 未结 6 995
不知归路
不知归路 2021-01-19 05:50

I have a base class like this:

 public class BaseModalCommand
 {

    protected object m_commandArgument;
    protected int m_commandID;
    protected int m_         


        
相关标签:
6条回答
  • 2021-01-19 05:50

    As best practice, your class fields should be marked as private and wrapped in a getter/setter property

    so instead of

    protected object m_commandArgument;
    

    use

    private object m_commandArgument;
    
    protected object CommandArgument {get; set;}
    

    Theres several advantages to this but a simple usage would be exception handling/validation in your setter.

    e.g.

    private string _email;
    protected string Email
    { 
       get { return _email; }
       set 
       {
           if(value.IndexOf("@") > 0)
               _email = value;
           else
                throw new ArgumentException("Not a valid Email");
       }
    }
    
    0 讨论(0)
  • 2021-01-19 05:50

    The advice of FxCop is sound. You don't want to expose protected fields to derived classes direclty. The state managed by the base class should be managed by the base class - never directly modified by any derived class.

    0 讨论(0)
  • 2021-01-19 06:07

    Basically, FxCop recommends that you should do

    private object m_commandArgument;
    
    protected object CommandArgument
    {
       get { return m_commandArgument; }
       set { m_commandArgument =value}
    }
    

    This is based on OO encapsulation rule- (One of three OO rules). You may want to check the value before assigning, and you want to ensure this is not directly manipulated by the derived class.

    0 讨论(0)
  • 2021-01-19 06:08

    Paul Alexander is correct and so is FxCop.

    You want to make your fields private and expose them through a property to prevent derived classes from changing the variable by themselves. Forcing them to go through a property gives the base class a chance to validate and/or reject any modifications.

    0 讨论(0)
  • 2021-01-19 06:12

    Use properties. Change the member variables to private and then setup protected properties for each member variable.

    Regards,
    Frank

    0 讨论(0)
  • 2021-01-19 06:17

    For any class, there are two kinds of uses by client code: code that references your class, and code that inherits your class. It's widely recognized that the second kind of use by far the most tightly coupled. Changes in your class directly affect their internal mechanics. Your exposing protected members like this means that changes in your base class will affect how your derived classes work in ways that are unpredictable without comparing the code of each base and derived class. Equally bad, your derived classes can modify the internals of the base class.

    If you really want to expose internal data members like this, wrap private data members in protected properties (as gisresearch suggests). These properties (along with any protected methods) constitute the inheritance interface of your class. Like any interface exposed to outside clients (whether through just defining public methods and properties, or through explicit interface implementation), this interface is something you will need to manage, particularly in larger code bases. An interface can be changed, but should be changed as a conscious decision.

    If you work with protected data members directly, you have much less control over the dependencies between base and derived classes. Trust me on this: not even being able to determine what effects a change may have can be a Very Unpleasant Thing.

    0 讨论(0)
提交回复
热议问题