@jfacorro has joined the channel
wazzup
@pabloa has joined the channel
¡Buen día!
Hola!
Gracias por la demo de ayer. Estuvo entretenido.
Un placer. Me alegro simple_smile
Después me di cuenta que fueron casi 4 horas
buenas
se pasó rápido el tiempo, con las preguntas y respuestas
@rustico has joined the channel
ya entendí lo que pasó con el async/put! ayer usando el chan con buffer... async/put! es asíncrono, y si no hay espacio en el buffer los puts se acumulan en un "puts bufffer" que está limitado a 1024 items... esto es en el FixedBuffer, que es el default... usando (chan (sliding-buffer 2)) (o dropping-buffer) entonces simplemente se descarta alguno de los mensajes para hacer lugar
Ante la pregunta de "entonces para qué sirve el buffer?", la respuesta es async/>!! que es como put (intenta agregar un mensaje al chan) pero bloquea si el buffer está full:
Usage: (>!! port val)
puts a val into port. nil values are not allowed. Will block if no
buffer space is available. Returns true unless port is already closed.
una referencia a lo de "buffered puts" y el límite de 1024: https://groups.google.com/d/msg/clojure/NIPIzJ7l6RA/QEiIRAk7TgoJ
Una buena respuesta de Stuart Sierra en SO: http://stackoverflow.com/a/24955514/1389573
Interesante.