Autrefois cantonnée aux laboratoires ou aux esprits les plus fous, la programmation fonctionnelle s'invite depuis quelques années dans les applications web et d'entreprises au travers de langages comme Scala, F# mais aussi JavaScript, au point de devenir un des sujets chaud du moment.
Mais les habitudes ont la vie dure, et sortir de sa zone de confort de développeur impératif maître de Java, Python ou PHP n'est pas chose facile, les bénéfices n'étant pas forcément évidents.
C'est toutefois le chemin que je vous propose d'entreprendre, au travers d'une introduction pragmatique aux concepts et principes portés par la programmation fonctionnelle.
2. Ce qui compte
C’est les valeurs !
Introduction à la
programmation fonctionnelle
3. Linkvalue | whoami
Moi ?
@raphaelbacconni
3
Lead Dev Backend @LinkValue
• Développeur Web
• PHP
• Java
• Scala, JavaScript
• … débute la programmation fonctionnelle avec Scala en
janvier 2015
• … apprécie la programmation fonctionnelle depuis ± juillet
2015
4. Why FP
matters ?
Vous avez dit fonctionnelle ?
Des programmes comme suite
d’applications
Sortir du labo
SOMMAIRE
Linkvalue | sommaire
4
Functions
Everywhere
Function
Closure
Memoïsation
Function Composition
A D T
Algebraic Data Types
Call me Maybe
Traiter les erreurs
5. Linkvalue | Why FP matters ?
Vous avez dit “fonctionnelle” ?
5
Qu’est-ce que la programmation fonctionnelle ?
• Un nouveau langage ?
• Une nouvelle architecture ?
• Une manière de rédiger ses tests ?
• Un nouveau framework JavaScript ?
7. Linkvalue | Why FP matters ?
Vous avez dit “fonctionnelle” ?
7
Qu’est-ce que la programmation fonctionnelle ?
• Un nouveau langage ?
• Non ! Mais les langages exposent des apis dédiées au fonctionnel
• Une nouvelle architecture ?
• Non ! Mais de nombreux design patterns sont transposables
• Oui… de nouvelles architectures en découlent
• Une manière de rédiger ses tests ?
• Non ! Mais permet d’écrire du code facilement testable
• Un nouveau framework JavaScript ?
• Non ! Mais il existe de nombreux frameworks FP
• … et ce n’est pas non plus (seulement) faire des filter / map / reduce !
8. Linkvalue | Why FP matters ?
Des programmes comme suites d’applications
8
Penser mathématiques
• Toute expression produit une valeur
• Basé sur le lambda calcul (Alonzo Church, 1930’s) : tout est fonction
• Influence de la théorie des catégories
• Parfois présentée comme opposée à la POO
• …
9. Linkvalue | Why FP matters ?
Des programmes comme suites d’applications
9
Application informatique
• Ne plus raisonner en fonction de changement d’état
• Appliquer une fonction sur des inputs produit toujours 1 même résultat
• Principe de substitution et transparence référentielle
• Fonction « pure »
• Données immuables
• Lisp (1958), Scheme (1975), Erlang (1987), Haskell (1990)
• ML (1973, 1983)
16. W h y F P m a t t e r s ?
Vous avez dit fonctionnelle ?
Des programmes comme suite
d’applications
Sortir du labo
SOMMAIRE
Linkvalue | sommaire
16
Functions
Everywhere
Function
Closure
Memoïsation
Function Composition
A D T
Algebraic Data Types
Call me Maybe
Traiter les erreurs
21. Linkvalue | Functions Everywhere
Function as First Class citizen
21
Multiparadigme – Approche fonctionnelle
22. Linkvalue | Functions Everywhere
Function as First Class citizen
22
Multiparadigme – Approche fonctionnelle
23. Linkvalue | Functions Everywhere
TP : Filtrer les utilisateurs en fonction de la conf
23
24. Linkvalue | Functions Everywhere
TP : Filtrer les utilisateurs en fonction de la conf
24
25. Linkvalue | Functions Everywhere
Closure
25
Principes
• Fonction qui peut accéder aux variables du scope
• Permet d’embarquer un contexte
• Initialiser des valeurs depuis une fonction constructeur
31. Linkvalue | Functions Everywhere
Function composition
31
Principes
• Créer une fonction qui appliquera successivement n fonctions
• Permet d’appliquer des transformations indépendamment du contexte
• Currying & Partiall application function
• Allège l’écriture de code
32. Linkvalue | Functions Everywhere
TP : composer nos fonctions d’affichage
32
Il nous faut :
• Enrichir les fonctions de sélection d’une donnée
• Préparer les appels de fonctions avec les paramètres à disposition
• Transformer légèrement la fonction d’affichage
33. Linkvalue | Functions Everywhere
TP : composer nos fonctions d’affichage
33
Il nous faut :
• Enrichir les fonctions de sélection d’une donnée
34. Linkvalue | Functions Everywhere
TP : composer nos fonctions d’affichage
34
Il nous faut :
• Enrichir les fonctions de sélection d’une donnée
• Préparer les appels de fonctions avec les paramètres à disposition
35. Linkvalue | Functions Everywhere
TP : composer nos fonctions d’affichage
35
Il nous faut :
• Enrichir les fonctions de sélection d’une donnée
• Préparer les appels de fonctions avec les paramètres à disposition
• Transformer légèrement la fonction d’affichage
36. W h y F P m a t t e r s ?
Vous avez dit fonctionnelle ?
Des programmes comme suite
d’applications
Sortir du labo
SOMMAIRE
Linkvalue | sommaire
36
F u n c t i o n s
E v e r y w h e r e
Function
Closure
Memoïsation
Function Composition
ADT
Algebraic Data Types
Call me Maybe
Traiter les erreurs
41. Linkvalue | Algebraic Data Types
Gérer les erreurs
41
Call me maybe : le type Option
• Conteneur qui contient éventuellement une valeur
• None : vide
• Some : contient une valeur
• Permet d’appliquer des transformations sans avoir à gérer l’absence
de résultat
• Évite les NullPointerException
• Permet de définir une application par défaut en cas d’absence de
résultat
• Aussi appelé Maybe …
47. Linkvalue | Algebraic Data Types
Gérer les erreurs
47
La liberté c’est de choisir, et choisir c’est renoncer : Le type Either
48. Linkvalue | Algebraic Data Types
Traiter les erreurs : Either Type
48
Catégoriser les retours avec Either
• Conteneur qui contient distinctement la valeurs calculée par le
traitement ou une valeur alternative si le traitement échoue
• Left : Contiendra une information sur l’erreur si une erreur survient
• Right : Contiendra la valeur telle qu’on l’attend
• Dans le meilleur des cas : parcours semblable au parcours d’une
Option
• On récupère l’erreur sous forme d’une valeur
50. Linkvalue | Pour conclure…
Pour conclure
50
On aime !
• Repenser la manière dont on crée des programmes
• Focus sur les traitements et les transformations
• Penser valeur
• Renvoyer les effets de bord en périphérie du cœur de l’application
Does FP rules the world ?
• On doit faire avec les effets de bord: le fonctionnel pur est compliqué
dans une application d’entreprise
• Coût du ticket d’entrée peut être élevé
• Haut niveau d’abstraction : certains traitements peuvent être plus
performants en mode impératif
• Langages multiparadigmes offrent le choix
• Possible d’appliquer les concepts de FP dans des langages impératifs