Leggendo un articolo caotico sugli aspetti negativi di OOP a favore di qualche altro paradigma, ho incontrato un esempio di cui non riesco a trovare troppa colpa.
Voglio essere aperto alle argomentazioni dell'autore, e anche se in teoria posso comprenderne i punti, in particolare un esempio sto facendo fatica a immaginare come sarebbe meglio implementato, per esempio, in un linguaggio FP.
// Consider the case where “SimpleProductManager” is a child of
// “ProductManager”:
public class SimpleProductManager implements ProductManager {
private List products;
public List getProducts() {
return products;
}
public void increasePrice(int percentage) {
if (products != null) {
for (Product product : products) {
double newPrice = product.getPrice().doubleValue() *
(100 + percentage)/100;
product.setPrice(newPrice);
}
}
}
public void setProducts(List products) {
this.products = products;
}
}
// There are 3 behaviors here:
getProducts()
increasePrice()
setProducts()
// Is there any rational reason why these 3 behaviors should be linked to
// the fact that in my data hierarchy I want “SimpleProductManager” to be
// a child of “ProductManager”? I can not think of any. I do not want the
// behavior of my code linked together with my definition of my data-type
// hierarchy, and yet in OOP I have no choice: all methods must go inside
// of a class, and the class declaration is also where I declare my
// data-type hierarchy:
public class SimpleProductManager implements ProductManager
// This is a disaster.
Nota che non sto cercando una confutazione a favore o contro gli argomenti dello scrittore per "C'è qualche ragione razionale per cui questi 3 comportamenti dovrebbero essere collegati alla gerarchia dei dati?".
Quello che sto chiedendo in particolare è come sarebbe modellato / programmato questo esempio in un linguaggio FP (codice reale, non teoricamente)?