Fork me on GitHub
#clojure-argentina
<
2015-09-03
>
pabloa15:09:04

¡Buen día!

pabloa15:09:08

Gracias por la demo de ayer. Estuvo entretenido.

nberger15:09:46

Un placer. Me alegro simple_smile

nberger15:09:27

Después me di cuenta que fueron casi 4 horas

jfacorro16:09:20

se pasó rápido el tiempo, con las preguntas y respuestas

nberger17:09:36

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

nberger17:09:51

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.

nberger17:09:27

una referencia a lo de "buffered puts" y el límite de 1024: https://groups.google.com/d/msg/clojure/NIPIzJ7l6RA/QEiIRAk7TgoJ

nberger18:09:14

Una buena respuesta de Stuart Sierra en SO: http://stackoverflow.com/a/24955514/1389573

pabloa18:09:32

Interesante.