De ce sunt mai bune actiunile de IO decat instructiunile de I/O ?

From HaskellWiki

Sunt mai multe motive. Actiunile de IO sunt mult mai flexibile decat instructiunile de IO. Intr-un limbaj de programare obisnuit, de acum doua trei decenii, compilat sau nu, ar fi fost dificil sa manipulati instructiunile de I/O succesive schimbandu-le dinamic ordinea la executie, rulindu-le intr-un sens apoi in altul sau pe sarite, dupa gust si nevoi.

Iata un exemplu in care aceleasi trei instructiuni de scriere care formeaza un bloc implementat ca lista sunt rulate in ordine, in ordine inversa apoi pe sarite (se sare peste prima).

module Main where


todolist ::[ IO () ]

todolist = [ putStr " seful " , putStr " este " , putStr " aclamat " ]


Constanta todolist este o lista de actiuni de IO.


Executia interactiva a setului de instructiuni:

Main> sequence_ $ reverse todolist
 aclamat  este  seful
Main> sequence_ todolist
 seful  este  aclamat
Main> sequence_ $ tail todolist
 este  aclamat
Main>

Se pot imagina si exemple putin mai elaborate. De exemplu programul main cere un caracter si dupa cum el este 1 sau 2 sau 3 executa aceeasi secventa in ordine diferita.
Notati si faptul ca acest mic exemplu cu schimbarea ordinii nu este principalul sau singurul raspuns posibil la intrebarea privitoare la superioritatea actiunilor de IO asupra instructiunilor de I/O din limbajele traditionale. Mai exista si alte motive.


Pagina indexata la indexul Categories:Ro


<= Inapoi la pagina principala Ro/Haskell.

<- Inapoi la Intrebarile incepatorului Ro/Haskell.