// Copyright 2009 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package main import "fmt" type Request struct { a, b int replyc chan int // reply channel inside the Request } type binOp func(a, b int) int func run(op binOp, req *Request) { req.replyc <- op(req.a, req.b) } func server(op binOp, service chan *Request) { for { req := <-service // requests arrive here // start goroutine for request: go run(op, req) // don't wait for op } } func startServer(op binOp) chan *Request { reqChan := make(chan *Request) go server(op, reqChan) return reqChan } func main() { adder := startServer(func(a, b int) int { return a + b }) const N = 100 var reqs [N]Request for i := 0; i < N; i++ { req := &reqs[i] req.a = i req.b = i + N req.replyc = make(chan int) adder <- req } // checks: for i := N - 1; i >= 0; i-- { // doesn't matter what order if <-reqs[i].replyc != N+2*i { fmt.Println("fail at", i) } else { fmt.Println("Request ", i, " is ok!") } } fmt.Println("done") }