Реализует против расширяет: когда использовать? Какая разница?

Пожалуйста, объясните простым для понимания языком или ссылкой на какую-нибудь статью.

15 ответов

Решение

extends для расширения класса.

implements для реализации интерфейса

Разница между интерфейсом и обычным классом заключается в том, что в интерфейсе нельзя реализовать ни один из объявленных методов. Только класс, который "реализует" интерфейс, может реализовать методы. Интерфейс C++, эквивалентный интерфейсу, будет абстрактным классом (не ТОЧНО таким же, но в значительной степени).

Также Java не поддерживает множественное наследование для классов. Это решается с помощью нескольких интерфейсов.

 public interface ExampleInterface {
    public void doAction();
    public String doThis(int number);
 }

 public class sub implements ExampleInterface {
     public void doAction() {
       //specify what must happen
     }

     public String doThis(int number) {
       //specfiy what must happen
     }
 }

сейчас расширяю класс

 public class SuperClass {
    public int getNb() {
         //specify what must happen
        return 1;
     }

     public int getNb2() {
         //specify what must happen
        return 2;
     }
 }

 public class SubClass extends SuperClass {
      //you can override the implementation
      @Override
      public int getNb2() {
        return 3;
     }
 }

в этом случае

  Subclass s = new SubClass();
  s.getNb(); //returns 1
  s.getNb2(); //returns 3

  SuperClass sup = new SuperClass();
  sup.getNb(); //returns 1
  sup.getNb2(); //returns 2

Я предлагаю вам еще немного изучить динамическое связывание, полиморфизм и общее наследование в объектно-ориентированном программировании.

Я заметил, у вас есть несколько вопросов C++ в вашем профиле. Если вы понимаете концепцию множественного наследования от C++ (имеется в виду классы, которые наследуют характеристики более чем от одного другого класса), Java не позволяет этого, но имеет ключевое слово interfaceчто-то вроде чистого виртуального класса в C++. Как уже упоминали многие люди, вы extend класс (и вы можете расширить только от одного), и вы implement интерфейс - но ваш класс может реализовать столько интерфейсов, сколько вам нравится.

Т.е. эти ключевые слова и правила, регулирующие их использование, очерчивают возможности множественного наследования в Java (у вас может быть только один суперкласс, но вы можете реализовать несколько интерфейсов).

Обычно реализует используемый для реализации интерфейс и расширяет используемый для расширения поведения базового класса или абстрактного класса.

extends: производный класс может расширять базовый класс. Вы можете переопределить поведение установленных отношений. Производный класс " является " типом базового класса

реализует: вы выполняете контракт. Класс, реализующий интерфейс, " имеет " возможность.

С выпуском Java 8 интерфейс может иметь методы по умолчанию в интерфейсе, который обеспечивает реализацию в самом интерфейсе.

Обратитесь к этому вопросу, чтобы узнать, когда использовать каждый из них:

Интерфейс против абстрактного класса (общий ОО)

Пример, чтобы понять вещи.

public class ExtendsAndImplementsDemo{
    public static void main(String args[]){

        Dog dog = new Dog("Tiger",16);
        Cat cat = new Cat("July",20);

        System.out.println("Dog:"+dog);
        System.out.println("Cat:"+cat);

        dog.remember();
        dog.protectOwner();
        Learn dl = dog;
        dl.learn();

        cat.remember();
        cat.protectOwner();

        Climb c = cat;
        c.climb();

        Man man = new Man("Ravindra",40);
        System.out.println(man);

        Climb cm = man;
        cm.climb();
        Think t = man;
        t.think();
        Learn l = man;
        l.learn();
        Apply a = man;
        a.apply();

    }
}

abstract class Animal{
    String name;
    int lifeExpentency;
    public Animal(String name,int lifeExpentency ){
        this.name = name;
        this.lifeExpentency=lifeExpentency;
    }
    public void remember(){
        System.out.println("Define your own remember");
    }
    public void protectOwner(){
        System.out.println("Define your own protectOwner");
    }

    public String toString(){
        return this.getClass().getSimpleName()+":"+name+":"+lifeExpentency;
    }
}
class Dog extends Animal implements Learn{

    public Dog(String name,int age){
        super(name,age);
    }
    public void remember(){
        System.out.println(this.getClass().getSimpleName()+" can remember for 5 minutes");
    }
    public void protectOwner(){
        System.out.println(this.getClass().getSimpleName()+ " will protect owner");
    }
    public void learn(){
        System.out.println(this.getClass().getSimpleName()+ " can learn:");
    }
}
class Cat extends Animal implements Climb {
    public Cat(String name,int age){
        super(name,age);
    }
    public void remember(){
        System.out.println(this.getClass().getSimpleName() + " can remember for 16 hours");
    }
    public void protectOwner(){
        System.out.println(this.getClass().getSimpleName()+ " won't protect owner");
    }
    public void climb(){
        System.out.println(this.getClass().getSimpleName()+ " can climb");
    }
}
interface Climb{
    public void climb();
}
interface Think {
    public void think();
}

interface Learn {
    public void learn();
}
interface Apply{
    public void apply();
}

class Man implements Think,Learn,Apply,Climb{
    String name;
    int age;

    public Man(String name,int age){
        this.name = name;
        this.age = age;
    }
    public void think(){
        System.out.println("I can think:"+this.getClass().getSimpleName());
    }
    public void learn(){
        System.out.println("I can learn:"+this.getClass().getSimpleName());
    }
    public void apply(){
        System.out.println("I can apply:"+this.getClass().getSimpleName());
    }
    public void climb(){
        System.out.println("I can climb:"+this.getClass().getSimpleName());
    }
    public String toString(){
        return "Man :"+name+":Age:"+age;
    }
}

выход:

Dog:Dog:Tiger:16
Cat:Cat:July:20
Dog can remember for 5 minutes
Dog will protect owner
Dog can learn:
Cat can remember for 16 hours
Cat won't protect owner
Cat can climb
Man :Ravindra:Age:40
I can climb:Man
I can think:Man
I can learn:Man
I can apply:Man

Важные моменты для понимания:

  1. Собака и Кошка - животные, и они расширились remember () а также protectOwner () путем обмена name,lifeExpentency от Animal
  2. Кошка может подняться (), а собака - нет. Собака может думать (), а кошка - нет. Эти конкретные возможности добавляются в Cat а также Dog путем реализации этой возможности.
  3. Человек не животное, но он может Think,Learn,Apply,Climb

Просматривая эти примеры, вы можете понять, что

Несвязанные классы могут иметь возможности через интерфейс, но связанные классы переопределяют поведение через расширение базовых классов.

Как показано на рисунке ниже, класс расширяет другой класс, интерфейс расширяет другой интерфейс, но класс реализует интерфейс. введите описание изображения здесь

Для более подробной информации

extends это когда вы наследуете от базового класса (т.е. расширяете его функциональность).

implements для когда вы реализуете интерфейс.

Вот хорошее место для начала: интерфейсы и наследование.

class может только "реализовать" interface, Класс только "расширяет" class, Аналогично interface может продлить другой interface,

class может продлить только один другой class, class может реализовать несколько interfaces.

Если вместо этого вы больше заинтересованы в знании, когда использовать abstract classэс и interfaces, обратитесь к этой теме: интерфейс против абстрактного класса (общий OO)

Интерфейс - это описание действий, которые объект может выполнять... например, когда вы нажимаете на выключатель света, свет включается, вам все равно, как, просто так и происходит. В объектно-ориентированном программировании Интерфейс - это описание всех функций, которые должен иметь объект, чтобы быть "Х". Опять же, в качестве примера, все, что "ACTS LIKE" источник света, должно иметь метод turn_on() и метод turn_off(). Назначение интерфейсов состоит в том, чтобы позволить компьютеру применять эти свойства и знать, что объект типа T (независимо от интерфейса) должен иметь функции, называемые X,Y,Z и т. Д.

Интерфейс - это структура / синтаксис программирования, которая позволяет компьютеру применять определенные свойства к объекту (классу). Например, скажем, у нас есть класс автомобилей, класс скутеров и класс грузовиков. Каждый из этих трех классов должен иметь действие start_engine(). То, как "двигатель запускается" для каждого транспортного средства, остается за каждым конкретным классом, но тот факт, что у него должно быть действие start_engine, является областью интерфейса.

Оба ключевых слова используются при создании собственного нового класса на языке Java.

Разница: implements означает, что вы используете элементы интерфейса Java в вашем классе. extends означает, что вы создаете подкласс базового класса, который вы расширяете. Вы можете расширить только один класс в своем дочернем классе, но вы можете реализовать столько интерфейсов, сколько захотите.

Обратитесь к странице документации оракула на интерфейсе для получения дополнительной информации.

Это может помочь уточнить, что такое интерфейс, и соглашения об их использовании.

Расширяется: используется для получения атрибутов родительского класса в базовый класс и может содержать уже определенные методы, которые могут быть переопределены в дочернем классе.

Реализует: это используется для реализации интерфейса (родительский класс только с сигнатурами функций, но не их определениями) путем определения его в дочернем классе.

Существует одно специальное условие: "Что если я хочу, чтобы новый интерфейс был дочерним по отношению к существующему интерфейсу?". В вышеупомянутом условии дочерний интерфейс расширяет родительский интерфейс.

  • А расширяет Б:

    A и B оба класса или оба интерфейса

  • А реализует Б

    A это класс, а B это интерфейс

  • Оставшийся случай, когда A - это интерфейс, а B - это класс, недопустим в Java.

Implements используется для интерфейсов, а extends используется для расширения класса.

Чтобы сделать его более понятным в более простом выражении, интерфейс - это как звучит, - интерфейс - модель, которую вы должны применить, следовать ей вместе со своими идеями.

Extend используется для классов, здесь вы расширяете то, что уже существует, добавляя в него больше функциональности.

Еще несколько заметок:

интерфейс может расширять другой интерфейс.

И когда вам нужно выбрать между реализацией интерфейса или расширением класса для конкретного сценария, переходите к реализации интерфейса. Потому что класс может реализовывать несколько интерфейсов, но расширять только один класс.

Мы используем SubClass расширяет SuperClass только тогда, когда подкласс хочет использовать некоторые функциональные возможности (методы или переменные экземпляра), которые уже объявлены в SuperClass, или если я хочу немного изменить функциональность SuperClass (переопределение метода). Но скажем, например, у меня есть класс Animal (SuperClass) и класс Dog (SubClass), и есть несколько методов, которые я определил в классе Animal, например. doEat ();, doSleep ();... и многое другое

Теперь мой класс Dog может просто расширить класс Animal, если я хочу, чтобы моя собака использовала любой из методов, объявленных в классе Animal, я могу вызвать эти методы, просто создав объект Dog. Таким образом, я могу гарантировать, что у меня есть собака, которая может есть и спать, и делать то, что я хочу, чтобы собака делала.

Теперь представьте, однажды какой-то любитель Кошек входит в наше рабочее пространство, и она пытается расширить класс Животных (кошки тоже едят и спят). Она создает объект Cat и начинает вызывать методы.

Но, скажем, кто-то пытается сделать объект класса животных. Вы можете сказать, как спит кошка, вы можете сказать, как ест собака, вы можете сказать, как пьет слон. Но это не имеет никакого смысла в создании объекта класса Animal. Потому что это шаблон, и мы не хотим никакого общего способа питания.

Поэтому вместо этого я предпочту создать абстрактный класс, экземпляр которого никто не может создать, но который можно использовать в качестве шаблона для других классов.

Таким образом, чтобы заключить, Интерфейс - не что иное как абстрактный класс (чистый абстрактный класс), который не содержит никаких реализаций метода, а только определения (шаблоны). Поэтому тот, кто реализует интерфейс, просто знает, что у него есть шаблоны doEat (); и doSleep (); но они должны определить свои собственные doEat (); и doSleep (); методы в соответствии с их потребностями.

Вы расширяете только тогда, когда хотите повторно использовать некоторую часть SuperClass (но имейте в виду, что вы всегда можете переопределить методы вашего SuperClass в соответствии с вашими потребностями), и вы реализуете, когда вам нужны шаблоны, и вы хотите определить их самостоятельно (в соответствии с вашими потребностями).

Я поделюсь с вами фрагментом кода: вы попробуете его с разными наборами входов и посмотрите на результаты.

class AnimalClass {

public void doEat() {

    System.out.println("Animal Eating...");
}

public void sleep() {

    System.out.println("Animal Sleeping...");
}

}

public class Dog extends AnimalClass implements AnimalInterface, Herbi{

public static void main(String[] args) {

    AnimalInterface a = new Dog();
    Dog obj = new Dog();
    obj.doEat();
    a.eating();

    obj.eating();
    obj.herbiEating();
}

public void doEat() {
    System.out.println("Dog eating...");
}

@Override
public void eating() {

    System.out.println("Eating through an interface...");
    // TODO Auto-generated method stub

}

@Override
public void herbiEating() {

    System.out.println("Herbi eating through an interface...");
    // TODO Auto-generated method stub

}


}

Определенные интерфейсы:

public interface AnimalInterface {

public void eating();

}


interface Herbi {

public void herbiEating();

}

В самых простых терминах extends используется для наследования от класса, а реализации используются для применения интерфейса в вашем классе.

расширяет:

public class Bicycle {
    //properties and methods
}
public class MountainBike extends Bicycle {
    //new properties and methods
}

реализует:

public interface Relatable {
    //stuff you want to put
}
public class RectanglePlus implements Relatable {
    //your class code
}

если у вас все еще есть путаница, прочитайте это: https://docs.oracle.com/javase/tutorial/java/IandI/subclasses.html https://docs.oracle.com/javase/tutorial/java/IandI/usinginterface.html

Когда подкласс расширяет класс, он позволяет подклассу наследовать (повторно использовать) и переопределять код, определенный в супертипе. Когда класс реализует интерфейс, он позволяет объекту, созданному из класса, использоваться в любом контексте, который ожидает значение интерфейса.

Реальная выгода здесь в том, что хотя мы реализуем что-либо, это просто означает, что мы используем эти методы как есть. Нет возможности для изменения их значений и типов возвращаемых данных.

Но когда мы расширяем что-либо, это становится расширением вашего класса. Вы можете изменить его, использовать его, использовать повторно, и для этого не обязательно возвращать те же значения, что и в суперклассе.

И классы, и интерфейсы являются контрактами. Они предоставляют методы и свойства, на которые полагаются другие части приложения.

Вы определяете интерфейс, когда вас не интересуют детали реализации этого контракта. Единственное, о чем нужно заботиться, - это наличие контракта (интерфейса).

В этом случае вы оставляете это на усмотрение класса, реализующего интерфейс, чтобы заботиться о деталях выполнения контракта. Только классы могут реализовывать интерфейсы.

extends используется, когда вы хотите заменить детали существующего контракта. Таким образом вы заменяете один способ выполнения контракта другим. Классы могут расширять другие классы, а интерфейсы могут расширять другие интерфейсы.

Extends используется, когда вам нужны атрибуты родительского класса / интерфейса в вашем дочернем классе / интерфейсе и implements используется, когда вам нужны атрибуты интерфейса в вашем классе.

Пример:

  1. Расширяет использование класса

    class Parent {

    }

    класс Child расширяет Parent {

    }

  2. Расширяет использование интерфейса

    интерфейс Parent {

    }

    Интерфейс Child расширяет Parent {

    }

  3. инвентарь

интерфейс A {

}

класс B реализует A {

}

Сочетание расширяет и реализует

interface A{

}

class B

{

}

class C implements A,extends B{

}

В Java класс (подкласс) расширяет другой класс (суперкласс) и может переопределить методы, определенные в суперклассе.

Хотя инструменты используются, когда класс пытается объявить методы, определенные в интерфейсе, указанный класс расширяется.

продолжается

  • класс расширяет только один класс
  • интерфейс расширяет один или несколько интерфейсов

инвентарь

  • класс реализует один или несколько интерфейсов
  • Интерфейсы "не может" реализует что-либо

абстрактные классы также действуют как классы с расширениями и реализациями

Эти два ключевых слова непосредственно связаны с Наследством, это основная концепция ООП. Когда мы наследуем некоторый класс другому классу, мы можем использовать extends, но когда мы собираемся наследовать некоторые интерфейсы для нашего класса, мы не можем использовать extends, мы должны использовать инструменты и мы можем использовать ключевое слово extends для наследования интерфейса от другого интерфейса.

Другие вопросы по тегам