You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
66 lines
1.8 KiB
66 lines
1.8 KiB
4 years ago
|
nio
|
||
|
==========
|
||
|
|
||
|
[![GoDoc](https://godoc.org/github.com/djherbis/nio?status.svg)](https://godoc.org/github.com/djherbis/nio)
|
||
|
[![Release](https://img.shields.io/github/release/djherbis/nio.svg)](https://github.com/djherbis/nio/releases/latest)
|
||
|
[![Software License](https://img.shields.io/badge/license-MIT-brightgreen.svg)](LICENSE.txt)
|
||
|
[![Build Status](https://travis-ci.org/djherbis/nio.svg)](https://travis-ci.org/djherbis/nio)
|
||
|
[![Coverage Status](https://coveralls.io/repos/djherbis/nio/badge.svg?branch=master)](https://coveralls.io/r/djherbis/nio?branch=master)
|
||
|
[![Go Report Card](https://goreportcard.com/badge/github.com/djherbis/nio)](https://goreportcard.com/report/github.com/djherbis/nio)
|
||
|
|
||
|
Usage
|
||
|
-----
|
||
|
|
||
|
The Buffer interface:
|
||
|
|
||
|
```go
|
||
|
type Buffer interface {
|
||
|
Len() int64
|
||
|
Cap() int64
|
||
|
io.ReadWriter
|
||
|
}
|
||
|
|
||
|
```
|
||
|
|
||
|
nio's Copy method concurrently copies from an io.Reader to a supplied nio.Buffer,
|
||
|
then from the nio.Buffer to an io.Writer. This way, blocking writes don't slow the io.Reader.
|
||
|
|
||
|
```go
|
||
|
import (
|
||
|
"github.com/djherbis/buffer"
|
||
|
"github.com/djherbis/nio"
|
||
|
)
|
||
|
|
||
|
buf := buffer.New(32*1024) // 32KB In memory Buffer
|
||
|
nio.Copy(w, r, buf) // Reads and Writes concurrently, buffering using buf.
|
||
|
```
|
||
|
|
||
|
nio's Pipe method is a buffered version of io.Pipe
|
||
|
The writer return once its data has been written to the Buffer.
|
||
|
The reader returns with data off the Buffer.
|
||
|
|
||
|
```go
|
||
|
import (
|
||
|
"gopkg.in/djherbis/buffer.v1"
|
||
|
"gopkg.in/djherbis/nio.v2"
|
||
|
)
|
||
|
|
||
|
buf := buffer.New(32*1024) // 32KB In memory Buffer
|
||
|
r, w := nio.Pipe(buf)
|
||
|
```
|
||
|
|
||
|
Installation
|
||
|
------------
|
||
|
```sh
|
||
|
go get gopkg.in/djherbis/nio.v2
|
||
|
```
|
||
|
|
||
|
For some pre-built buffers grab:
|
||
|
```sh
|
||
|
go get gopkg.in/djherbis/buffer.v1
|
||
|
```
|
||
|
|
||
|
Mentions
|
||
|
------------
|
||
|
[GopherCon 2017: Peter Bourgon - Evolutionary Optimization with Go](https://www.youtube.com/watch?v=ha8gdZ27wMo&start=2077&end=2140)
|