layout | title | permalink | resource |
---|---|---|---|
page |
Tecnologías |
/tecnologias/ |
true |
Si estuviste leyendo las otras páginas habrás visto que mencionamos bastantes tecnologías diferentes, y eso quizás te parezca interesante, pero quizas te aterre un poco. Así que te contamos un poco mejor cómo viene la mano:
En la materia queremos contarte conceptos de arquitectura e implementación de una aplicación concurrente (es decir, cualquier aplicación que sea usada por más una persona y/o tenga más de un proceso) que nos parecen novedosos y útiles hoy en dia. Y de paso, presentarte algunas tecnologías que no son de laboratorio, sino que se usan en la industria.
Así que no vamos a matarte con 18,5 lenguajes, 40 frameworks, 39 bibliotecas, 71 test runners y 3,141516 tipos de cerveza (¡ufa!). Sino que vamos a elegir las 3 o como mucho 4 tecnologías más representativas de lo que queremos explicar, usando aquellas de uso industrial cuando sea posible.
Asumimos que vos no sabés nada ni de las tecnologías que vamos a ver, ni de los conceptos, y de hecho, ni siquiera de concurrencia (mas allá de un vago recuerdo de esos días en que eras joven y cursabas operativos). Así que tranquila/o, vamos a explicar todo lo que vamos a usar (al menos, a un nivel razonable, algunas cosas para leer algún día te mandaremos, esperamos que no te enojes)
Ahora sí, las tecnologías:
Es Erlang, pero con un sombrero nuevo
Lo queremos para entender:
- actores. Podriiiiiiamos haber usado Erlang (el papá de toda la movida) pero es un poco áspero, así que vamos por Elixir que es algo así como el Erlang de los 2010: bonito, sencillito, no habla mal de tu mamá. ¿Por qué no Akka y Scala? En clase te contamos.
- Tolarancia a fallos
- Distribución y algunas otras ideas de arquitecutra
Via Node.js, alguito de Express y algunas bibliotecas, como Bluebird y RxJS.
Vamos a usarlo para entender:
- Event Loops/Reactors
- CPS
- Promises
- y las extensiones reactivas, de las que todos hablan, algunos usan, pocos entienden, y ninguno sabe por qué. O casi.
"Te acuerdas de Haskell? Volvió, y en forma de mónadas!".
Ninguna materia de concurrencia que se precie podría hacer caso omiso a las bondades del paradigma funcional. Lo queremos para entender
- algunos patrones que están presentes a lo largo de todas las tecnologías e ideas que vimos antes.
- algunas ideas de arquitectura como asilamiento de efectos y estado
- STM. Una forma interesante de manejar la memoria de forma concurrente. La verdad es que nos hubiera encantado ver STM con Clojure (que tiene una de las mejores implementaciones), pero consideramos que meternos con Lisp por unas pocas horas de clase era demasiado. Quizás en otro cuatrimestre.
Ah, y para que no digan que les mentimos, la primera clase vamos a ver dos líneas de Ruby, para poder comparar con la concurrencia tradicional y después olvidarlas. ¿¿¿O querían ver C???