Not sure why the go pipe doesn’t take a size for the inner channel to make the 
synchronous nature optional. 

> On Nov 21, 2019, at 10:44 PM, Robert Engels <reng...@ix.netcom.com> wrote:
> 
> Sorry in reading the implementation of a pipe in Go, it may not have the 
> desired semantics, especially with a large write buffer since writes and 
> reads are 1 to 1 (very weird impl - this is not a traditional pipe). Dan’s 
> library is a better choice. 
> 
>> On Nov 21, 2019, at 10:37 PM, Robert Engels <reng...@ix.netcom.com> wrote:
>> 
>> The OP specifically requested io.Reader/Writer interfaces. 
>> 
>> A pipe is what he wants. Not a ring buffer. (A pipe essentially has a ring 
>> buffer in the implementation though). 
>> 
>>>> On Nov 21, 2019, at 10:20 PM, Dan Kortschak <d...@kortschak.io> wrote:
>>> 
>>> There is this: https://godoc.org/bitbucket.org/ausocean/utils/ring
>>> 
>>> It has been used in production fairly extensively.
>>> 
>>>>> On Thu, 2019-11-21 at 19:47 -0800, Marcin Romaszewicz wrote:
>>>> Hi All,
>>>> 
>>>> Before I reinvent the wheel, and because this wheel is particularly
>>>> tricky
>>>> to get right, I was wondering if anyone was aware of a a library
>>>> providing
>>>> something like this
>>>> 
>>>> - conforms to io.Reader
>>>> - conforms to io.Writer
>>>> - Contains a buffer of fixed size, say, 64MB. If you try to write
>>>> when the
>>>> buffer is too full, write blocks. When you try to read from an empty
>>>> one,
>>>> read blocks.
>>>> 
>>>> This describes the behavior of make(chan byte, 64 * MB), however, it
>>>> doesn't seem to be efficient to do this with a channel. Say I'm
>>>> transferring a few hundred GB via this mechanism. A chan of byte
>>>> would need
>>>> a few hundred billion byte writes, and a few hundred billion reads.
>>>> Doesn't
>>>> sound like it could be efficient at all. You can't implement this
>>>> with a
>>>> channel of []byte, because you'd violate your buffering limit if you
>>>> pass
>>>> too large of a byte array, so you'd have to chop things up into
>>>> blocks, but
>>>> maybe that's simpler than a full fledged blocking ring buffer.
>>>> 
>>>> Anyhow, I've implemented such things in various OS level plumbing, so
>>>> I
>>>> know I can do it in Go much more easily, just hoping to avoid it :)
>>>> 
>>>> Thanks for any advice,
>>>> -- Marcin
>>>> 
>>> 
>>> -- 
>>> You received this message because you are subscribed to the Google Groups 
>>> "golang-nuts" group.
>>> To unsubscribe from this group and stop receiving emails from it, send an 
>>> email to golang-nuts+unsubscr...@googlegroups.com.
>>> To view this discussion on the web visit 
>>> https://groups.google.com/d/msgid/golang-nuts/152a954eaa3eea02514e71bb142904480241ad6c.camel%40kortschak.io.

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/16241014-EBD3-4232-8460-FEE735918ACB%40ix.netcom.com.

Reply via email to