|
|
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Всем привет. Пытаюсь переосмыслить Generics и возник вопрос, насколько рационально использовать фиктивный агрегирующий интерфейс/класс вместо использования & в wildcard-ах. Код: java 1. 2. 3. 4. 5. вместо Код: java 1. 2. 3. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 14:44 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Крошкин ДмитрийВсем привет. Пытаюсь переосмыслить Generics и возник вопрос, насколько рационально использовать фиктивный агрегирующий интерфейс/класс вместо использования & в wildcard-ах. Код: java 1. 2. 3. 4. 5. вместо Код: java 1. 2. 3. Если MyInterface ДОЛЖЕН сериализоваться- то логично. Если нет- то не логично. Добавляя в MyInterface новое свойство, надо понимать, что ты ограничиваешь все реализации, навязывая им это свойство. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 15:05 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Крошкин Дмитрий, Пофигу. Но здесь как с переменными и методами. Если ваш MyInterface имеет внятное имя, которое способствует пониманию кода, то да. Имеет смысл его создать. Например Код: java 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. Так и здесь. Если MyInterface действительно описывает почему класс относится к этому типу, то конечно же есть смысл такой интерфейс иметь. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 15:06 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Alexey TominЕсли MyInterface ДОЛЖЕН сериализоваться- то логично. Если нет- то не логично. А если использовать этот интерфейс как маркерный для классов использующих generic-и, чтобы отсеять неугодные классы. Про сериализацию немного не понял. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 16:07 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Крошкин ДмитрийAlexey TominЕсли MyInterface ДОЛЖЕН сериализоваться- то логично. Если нет- то не логично. А если использовать этот интерфейс как маркерный для классов использующих generic-и, чтобы отсеять неугодные классы. Про сериализацию немного не понял. Хотя никто не мешает внести этот маркерный интерфейс под крыло wildcard-а. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 16:14 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Крошкин ДмитрийAlexey TominЕсли MyInterface ДОЛЖЕН сериализоваться- то логично. Если нет- то не логично. А если использовать этот интерфейс как маркерный для классов использующих generic-и, чтобы отсеять неугодные классы. Ничего не понял. У Вас в голове каша. Интерфейс- это контракт, обязательства класса по отношению к клиентам. Увеличивая интерфейс (добавляя Serializable) - увеличиваете обязательства класса, реализующего этот интерфейс. Что такое маркерный, и какие классы неугодные- не понял. Крошкин ДмитрийПро сериализацию немного не понял. Объявляя класс (в т.ч. через интерфейс) Serializable, Вы накладываете на все классы обязательства продолжить корректную работу после того, как состояние классы было записано на диск (сеть и т.п.), а потом считан в новый объект. Это вообще говоря немало, а временами может создавать проблему (например если класс хочет работать с БД). ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 16:20 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Alexey TominКрошкин Дмитрийпропущено... А если использовать этот интерфейс как маркерный для классов использующих generic-и, чтобы отсеять неугодные классы. Ничего не понял. У Вас в голове каша. Интерфейс- это контракт, обязательства класса по отношению к клиентам. Увеличивая интерфейс (добавляя Serializable) - увеличиваете обязательства класса, реализующего этот интерфейс. Что такое маркерный, и какие классы неугодные- не понял. Крошкин ДмитрийПро сериализацию немного не понял. Объявляя класс (в т.ч. через интерфейс) Serializable, Вы накладываете на все классы обязательства продолжить корректную работу после того, как состояние классы было записано на диск (сеть и т.п.), а потом считан в новый объект. Это вообще говоря немало, а временами может создавать проблему (например если класс хочет работать с БД). Про кашу в голове - не стоит категорично судить. Маркерный - Cloneable, тот же Serializable. Для пояснения "отсеивать неугодных" - в случае использования "T extends Comparable<T> & Serializable" можно использовать объекты класса String, в случае "interface MyInterface<T> extends Comparable<T>, Serializable" использование возможно только объектов классы которых реализуют этот интерфейс. Состояние класса записано на диск? - очепятка? вероятно состояние объекта ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 17:28 |
|
||
|
Generics with multiple interfaces
|
|||
|---|---|---|---|
|
#18+
Крошкин ДмитрийМаркерный - Cloneable, тот же Serializable. Для пояснения "отсеивать неугодных" - в случае использования "T extends Comparable<T> & Serializable" можно использовать объекты класса String, в случае "interface MyInterface<T> extends Comparable<T>, Serializable" использование возможно только объектов классы которых реализуют этот интерфейс. Состояние класса записано на диск? - очепятка? вероятно состояние объекта Да, объекта. Про отсеивание неугодных - не надо так, надо думать о сути... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 18.12.2014, 20:33 |
|
||
|
|

start [/forum/topic.php?fid=59&fpage=146&tid=2126050]: |
0ms |
get settings: |
6ms |
get forum list: |
13ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
37ms |
get topic data: |
8ms |
get forum data: |
2ms |
get page messages: |
46ms |
get tp. blocked users: |
1ms |
| others: | 196ms |
| total: | 313ms |

| 0 / 0 |
