Prescriptivism and Descriptivism
Gautier DI FOLCO January 31, 2024 [Software engineering] #software engineering #design #haskell #functional programming #object-oriented programmingA long time ago I was watching another version of Romeu Moura's Prescriptivism vs Descriptivism.
The idea is illustrated by the point of view you can have on a "list":
- Prescriptive: as things should be (as in a specification)
- Descriptive: as things are (or at least, how things are observed)
Sometimes, in Haskell tutorials you have many references to Category Theory, they are often compared to Design Patterns and beginners report that they are way harder to grasp.
The thing is, whenever your define some types, you start by defining the datatype then you define the type class to characterize its property:
data AvlTree a = Node (AvlTree a) a (AvlTree a) | Leaf
(<>) = mergeAndBalance
mempty = Leaf
We can say that Category Theory is descriptive.
On another hand, when it comes to object-oriented programming, Design Patterns are the way to go.
The thing is, most of the time, they are implemented to solve a technical issue, they are implemented to be implemented.
Usually, they are named in order to reflect that:
or tagged:
Design Patterns in (OOP at least) are prescriptive.
Design Patterns exist in OOP to solve a lack of Higher-order constructions.
Another form of descriptive constructions are duck typing (at runtime) and structural typing (at compile time).
The duck typing in ruby:
# ...
end
end
# ...
end
end
x.refill
end
You can refill your Glass
in a gas station, but petrol is only good for some
cars.
The structural typing in go:
type Glass struct
type Car struct
type Refillable interface
func ()
func ()
func GasStation(x Refillable)