Should a class validate itself or create another class to validate it?

后端 未结 8 795
梦毁少年i
梦毁少年i 2021-02-01 17:30

Let\'s say I have a class like:

class NavigationData
{
  float roll;
  float pitch;
  double latitude;
  double longitude;
}

and if I want to c

相关标签:
8条回答
  • 2021-02-01 18:08

    I'd say have it validate itself as long as the valid values don't depend on what other classes use NavigationData.

    Basically, as long as latitude and pitch has to always be between +/- 90 degrees, and longitude and roll always be between +/- 180 degrees, keep the validator in the class.

    (By the way, what about heading?)

    0 讨论(0)
  • 2021-02-01 18:08

    It depends on the context. Sometimes, your object is absolutely valid internally, but in the context its values aren't acceptable.

    If you have simple Data Transfer Object then it probably shouldn't validate itself.

    If you have a class of Domain Model then it should do some validation.

    P.S. just my personal preference: isValid () instead of validate () when method returns boolean value.

    0 讨论(0)
  • 2021-02-01 18:09

    The right answer is: it depends.

    The natural place to put such object logic is in the object itself. Sometimes though the validation rules could be dependent on a rules engine or some kind of larger "framework" which validates stuff. Another situation where you wouldn't want to do validation inside the object is when validation belongs in another tier, or layer or the application, such as the view layer.

    0 讨论(0)
  • 2021-02-01 18:09

    Your class should be designed such a way and provide such methods that validate() is always true:

    • after any public constructor invoked
    • before and after any public method is invoked
    • (in C++-land) before destructor is invoked

    Such validate() methods are called class invariants and are important part of Design by Contract.

    0 讨论(0)
  • 2021-02-01 18:09

    Depends...

    Sometimes the validations are not part of the class itself, but business logic, and adding it to the class would prevent reutilization, and therefore, the usage of a validating class is good. Otherwise, the class should be able to validate itself.

    0 讨论(0)
  • 2021-02-01 18:10

    As it has already been said, it depends.

    But in your case, I would go for a different solution, create new immutable class for geo coordinates

    class GeoCoordinates
    {
        double Latitude;
        double Longitude;
    }
    

    And let this class validate that latitude and longitude are within valid limits. You will probably need this other places as well, for example.

    class Airport
    {
        GeoCoordinates Location;
        ...
    }
    
    0 讨论(0)
提交回复
热议问题