Припустим, у меня есть интерфейс с методом A. Я создаю два дочерних к нему интерфейса, один имеет метод B, второй - метод C. После чего создаю класс, реализующий оба дочерних интерфейса, и объявляю там методы A, B и C. Не возникнет ли проблем с реализацией метода А? Чаще всего насчет ситуаций с одинаковыми именами методов в интерфейсах предлагают отдельную реализацию. Мне, к примеру, нужно, чтобы там выполнялось только одно действие. Или стоит вынести метод A в отдельный интерфейс?

Принятый ответ

реализован в классе.
Скользкое понятие.
В любом случае, даже если дочерний интерфейс переобъявит метод A() вот так:
interface iB
{ new void A(); void B(); }
и твой класс Class_Example реализует его, у тебя будут выполнятся одни и те же действия
  1. И в случае iB b = new Class_Example(); b.A()
  2. И в случае iA a = new Class_Example(); a.A();
  3. И в случае Class_Example class_name = new Class_Example(); class_name.A().
В случае, когда интерфейс не переобъявляет метод A() даже говорить не приходиться - тем более будут те же действия.
Вообще здесь такая штука, по моему мнению конкретно в этом случае надо разбираться по факту проблемы, а не по возможной проблеме.
P.S.
Насчет интерфейсов "Полный справочник по C#" , стр 320.
`
ОЖИДАНИЕ РЕКЛАМЫ...

Показан только небольшой набор комментариев вокруг указанного. Перейти к актуальным.
0
9
9 лет назад
Отредактирован AsagiriGen
0
реализован в классе.
Скользкое понятие.
В любом случае, даже если дочерний интерфейс переобъявит метод A() вот так:
interface iB
{ new void A(); void B(); }
и твой класс Class_Example реализует его, у тебя будут выполнятся одни и те же действия
  1. И в случае iB b = new Class_Example(); b.A()
  2. И в случае iA a = new Class_Example(); a.A();
  3. И в случае Class_Example class_name = new Class_Example(); class_name.A().
В случае, когда интерфейс не переобъявляет метод A() даже говорить не приходиться - тем более будут те же действия.
Вообще здесь такая штука, по моему мнению конкретно в этом случае надо разбираться по факту проблемы, а не по возможной проблеме.
P.S.
Насчет интерфейсов "Полный справочник по C#" , стр 320.
Принятый ответ
0
29
9 лет назад
0
Чего за вопрос
В интерфейсах методы не реализуются
Интерфейсы содержат сигнатуры методов
Если сигнатура совпадает то в чем вообще вопрос?
0
28
9 лет назад
Отредактирован nvc123
0
Doc, вопрос в том что такое интерфейс
то что автор не понимает что из себя представляет интерфейс очевидно из текста вопроса
и лично мне кажется что в джаве интерфейсы больше распространены чем в шарпе, что может служить оправданием для автора
0
26
9 лет назад
0
Никто не говорил, что я реализую методы в интерфейсах. Не понимаю, откуда вы это взяли.
0
29
9 лет назад
0
Мне кажется что автор не понимаю что он хочет и то что он привел звучит очень странно. И вообще наследование интерфейсов это не менее странно
0
28
9 лет назад
0
alexprey, наследование интерфейсов иногда применяется(как правило наследуют интерфейс из API)
0
29
9 лет назад
0
nvc123, в редких случаях. Но использовать 3 интерфейса, которые друг друга наследуют....
это уже попахивает костылями
0
26
9 лет назад
Отредактирован lentinant
0
alexprey, начитавшись примеров по SOLID (которому в определенной мере должен следовать мой код на работе), я изначально предположил, что интерфейсы обычно придумываются так, чтобы был смысл создавать объект, реализующий только этот интерфейс. То есть, если у меня есть методы А, B и C, и у меня вряд ли будут объекты, которым будет нужен исключительно метод B или C, то нет смысла создавать отдельно интерфейс на каждый из них. Поэтому я решил, что для этих четырех случаев (объект использует только метод А, объект использует методы A и B, объект использует методы A и C, объект использует все методы) лучше всего сделать базовый интерфейс с обозначением метода А (сам по себе подходит для первого случая), от него создать интерфейсы с методами B и C (подходят для второго и третьего случаев), а для четвертого случая оптимально будет наследовать класс от второго и третьего интерфейса.
Но это было вчера, я с того времени существенно поменял "мировоззрение", и теперь у меня методы B и C, все же, в отдельных интерфейсах, независящих от интерфейса с методом А.
И это не меняет суть вопроса, который был не "стоит ли это использовать", а "как это работает". На который мне, кстати, уже давно дали ответ.
0
27
9 лет назад
Отредактирован Devion
0
public interface IFirst
{
    void A();
}

public interface ISecond
{
    void A();
}
Обращаем внимание на инкапсуляцию
public class MyClass1 : IFirst, ISecond
{
    void IFirst.A()
    {
        
    }

    void ISecond.A()
    {
        
    }
}

public class MyClass2 : IFirst, ISecond
{
    public void A()
    {

    }
}
Просто к теме за реализацию интерфейсов
0
29
9 лет назад
0
Extravert, а MyClass2 разве будет работать?
0
27
9 лет назад
Отредактирован Devion
0
alexprey, да
MyClass2 реализует общий для двух интерфейсов метод A(). Сами интерфейсы, как бы сказать, они же не содержат метода как таковые, они обязывают к реализации и абстрагируют. А один и тот же метод это или два разных уже другое дело.
Я почему-то думал, что второй способ как раз не вызывает вопросов :) в то время как с первым все не так гладко - чтобы использовать методы нужно приводить экземпляр к интерфейсу. А еще их "смешивать" можно.
Показан только небольшой набор комментариев вокруг указанного. Перейти к актуальным.
Чтобы оставить комментарий, пожалуйста, войдите на сайт.