Свойства и их абстракции. : Свободный полёт - Страница 6 fixfix
2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки




Начать новую тему Ответить на тему На страницу Пред.  1 ... 3, 4, 5, 6, 7, 8  След.
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 13:44 


18/11/10
381
Мюнхен
Xaositect в сообщении #385700 писал(а):
Правильно, но если у эллипса был такой метод, и он отнаследуется, то он будет неправильно работать у круга

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

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 13:48 
Заслуженный участник
Аватара пользователя


06/10/08
6422
kolas в сообщении #385703 писал(а):
Полиморфизм в руки, чтобы из эллипса сделать круг переопределяйте соответствующие методы.
Гм.
Я не могу переопределить метод void Ellipse::stretchX(double scale) так, чтобы он соответствовал своему названию (и предназначению).
Тут не переопределять надо, а рефакторить.

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 13:53 


18/11/10
381
Мюнхен
Xaositect в сообщении #385704 писал(а):
Гм.
Я не могу переопределить метод void Ellipse::stretchX(double scale) так, чтобы он соответствовал своему названию (и предназначению).
Тут не переопределять надо, а рефакторить.


Кстати, для таких скользких случаев можно использовать паттерн - декоратор, тогда можно будет развязаться от прямого наследования. Например:
еллипс -> фигура
круг -> фигура
круг <>-> еллипс

Далее конструктор круга принимает объект эллипс, и имеет только свойство - радиус, которое определяет свойства длина и высота у эллипса. Все остальные абстрактные методы класса фигуры, круг делегирует эллипсу.

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 13:59 
Заслуженный участник
Аватара пользователя


06/10/08
6422
В итоге вместо простой и понятной вещи [круг -> эллипс] получаем лишний класс и кучу кода.

Здесь надо просто делать, чтобы метод stretchX возвращал результат типа Ellipse. Мы с Joker_vD просто пытались объяснить, что некоторая проблема здесь за этим стоит.

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 14:09 


18/11/10
381
Мюнхен
Xaositect в сообщении #385709 писал(а):
Здесь надо просто делать, чтобы метод stretchX возвращал результат типа Ellipse

Ну и отлично, тогда у эллипса нужно сделать, чтобы методы stretchX и stretchY возвращали объект типа эллипс. У эллипса они будут реализованы так:
virtual Ellipse stretchX(value)
{
width = value;
return this;
}
...

у круга:
override Ellipse stretchX(value)
{
width = value;
return new Ellipse(width, hiegth);
}
....
double Radius
{
get{return radius;}
set{radius = value; width = value; hiegth = value;}
}

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 14:13 
Заслуженный участник
Аватара пользователя


06/10/08
6422
Да, это я и имел в виду. Заметьте, что вместо модифицирующего метода мы сделали немодифицирущий.
В итоге так можно и до функционального программирования и иммутабельности дойти :)

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 14:22 


18/11/10
381
Мюнхен
Xaositect в сообщении #385721 писал(а):
Заметьте, что вместо модифицирующего метода мы сделали немодифицирущий.

Да, но все равно это свойство (Radius) делегирует свою функциональность базовым(width, hiegth), так что правило подстановки работает.
Xaositect в сообщении #385721 писал(а):
В итоге так можно и до функционального программирования дойти :)

Согласен, да все едино, эти две парадигмы есть модель нашего мышления, т.е. это две реализации одной абстракции ;)

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 16:19 
Заслуженный участник
Аватара пользователя


30/01/06
72407
kolas в сообщении #385676 писал(а):
Теперь с помощью полиморфизма мы переопределяем в круге сеттер высота, и меняем там и высоту и длину на одно и тоже значение, тоже самое делаем с сеттером длина.

Человек даже не догадывается, что это некорректно, что за такие "сеттеры" руки вырывают.

Что позволено в графредакторе, не позволено в программировании, при оговорённых постусловиях и побочных эффектах.

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 19:54 
Заслуженный участник


27/04/09
28128

(Оффтоп)


 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 21:11 
Заслуженный участник
Аватара пользователя


30/01/06
72407

(Оффтоп)


 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение10.12.2010, 21:37 
Заслуженный участник


27/04/09
28128

(Оффтоп)


 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение11.12.2010, 13:07 


18/11/10
381
Мюнхен
Munin в сообщении #385908 писал(а):
Он предлагает в производном классе его нарушить.

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

-- Сб дек 11, 2010 16:53:45 --

Munin в сообщении #385908 писал(а):
В базовом классе контракт (инвариант) этого мутатора состоял в том, что вторая полуось эллипса не меняется.

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

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение11.12.2010, 13:54 
Заслуженный участник
Аватара пользователя


30/01/06
72407
kolas в сообщении #386078 писал(а):
Это называется не нарушить, а переопределить, это вполне нормальная практика в ооп, называется полиморфизм.

Это называется нарушать. В ООП нарушение контрактов нормальной практикой не является. Полиморфизм - это совсем другое, его роль как раз в выполнении контрактов.

kolas в сообщении #386078 писал(а):
В этой теме, Ваш снобизм неуместен, и даже выглядит глупо. Вы где-то говорили, что Вы сноб к безграмотности, но, к сожалению, сноб это не состояние, это класс.

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

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение11.12.2010, 14:16 
Заслуженный участник
Аватара пользователя


01/08/06
3140
Уфа
kolas, Вы действительно не знаете, что наследование квадрата от прямоугольника нарушает принцип подстановки?
The circle-ellipse problem... illustrates the difficulties which can occur when a base class contains methods which mutate an object in a manner which might invalidate a (stronger) invariant found in a derived class, causing the Liskov substitution principle to be violated.


-- Сб дек 11, 2010 16:29:18 --

Виноват, есть ещё более подходящая ссылка:
A typical example that violates LSP is a Square class that derives from a Rectangle class, assuming getter and setter methods exist for both width and height.... This problem cannot be easily fixed: if we can modify the setter methods in the Square class so that they preserve the Square invariant (i.e. keep the dimensions equal), then these methods will weaken (violate) the postconditions for the Rectangle setters, which state that dimensions can be modified independently.


-- Сб дек 11, 2010 16:38:11 --

Ну, и до кучи ещё ссылочку кину:
Из Marshall Cline's C++ FAQ про правильное проектирование наследования.

 Профиль  
                  
 
 Re: Свойства и их абстракции.
Сообщение13.12.2010, 09:41 


18/11/10
381
Мюнхен
Munin в сообщении #386095 писал(а):
В ООП нарушение контрактов нормальной практикой не является. Полиморфизм - это совсем другое, его роль как раз в выполнении контрактов.

Еще один минус в Вашу пользу, Вы плаваете в ооп, это явно заметно, зачем Вы пытаетесь оправдаться? Полиморфизм это не просто выполнение контракта, это способ выполнения контракта, и у разных классов он может быть разный, от сюда и приставка "поли". Что значит нарушить контракт, реализовать его неправильно? Но круг все контракты эллипса реализует правильно, и никаких новых контрактов не создает, так что правило подстановки работает корректно.

worm2 в сообщении #386100 писал(а):
наследование квадрата от прямоугольника нарушает принцип подстановки


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

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 114 ]  На страницу Пред.  1 ... 3, 4, 5, 6, 7, 8  След.

Модератор: Модераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group