Class vs. Interface

后端 未结 10 1441
孤城傲影
孤城傲影 2020-12-10 03:18

I have a quite basic question:

When should we decide to use Interface or Class for a specific class?

For example: says we have 2 classes, Customer and Doctor

相关标签:
10条回答
  • 2020-12-10 03:43
    • Read the wikipedia article

    • Read a book, then read the chapters about OOP again

    • In your example, Person should be a class, because it contains implementation details that are common to both a Doctor and a Customer.

    • interfaces don't have (and don't need) implementation details - they only denote what objects which implement them are doing. Not how. Why is this useful? Because when you are using the object you don't care how it's going to do its job.

    Let's take a look at a simple example - there is an interfaces Comparable (in Java at least). It denotes that its implementors can be compared with each other. So you can have two classes:

    class Doctor implements Comparable {..}
    
    class Customer implements Comparable {..}
    

    Now you can have a common method which takes any set of objects which implement Comparable and call comparable1.compareTo(comparable2), because you know they can perform comparison - it's denoted by their interface.

    0 讨论(0)
  • 2020-12-10 03:45
    • Interface - describe the behavior
    • Class - do the behavior

    A class extending another class inherits the behavior. On the other hand, implementing an interface just says it need to behave that way but the class still has to know the how-to.

    Besides single inheritance limitations, code using interfaces are easier to refactor and test, e.g. provide a mock implementation for a database access object in unit tests.

    So, the real answer is, it depends on your design.

    It may be that you use interfaces to describe behavior, and abstract parent classes to implement the behavior that can be inherited by subclasses. Or maybe the subclasses are so different that each implements the interface in their own way.

    0 讨论(0)
  • 2020-12-10 03:45

    Simply put, you use classes when there is code/implementation involved and interfaces when it is just interface descriptions. When referring to objects in your code, prefer to refer to the interfaces as it makes it easier to replace the actual implementation (or add more and different implementations).

    And yes, both Docor and Customer/Patient are likely to implement or extend Person.

    0 讨论(0)
  • 2020-12-10 03:49

    Interfaces are used to enforce certain Methods/Properties. In a nutshell- an interface is a set of rules.

    A class can be used to inherit/override base functionality.

    Have a look at

    • Difference between class and interface in C#?
    • C#: Interface vs. Class
    • Abstract Class versus Interface
    • interface (C# Reference)
    0 讨论(0)
提交回复
热议问题