wazzup
¡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
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.