微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

[日常] Go语言圣经--并发的循环习题

练习 8.4: 修改reverb2服务器,在每一个连接中使用sync.WaitGroup来计数活跃的echo goroutine。当计数减为零时,关闭TCP连接的写入,像练习8.3中一样。验证一下你的修改版netcat3客户端会一直等待所有的并发“喊叫”完成,即使是在标准输入流已经关闭的情况下。

重点:等待所有的goroutine执行完成后再关闭TCP连接

Highlighter">
rush:go;gutter:true;">package main

import (
"bufio"
"fmt"
"log"
"net"
"strings"
"time"
"sync"
)

func main() {
listener,err := net.Listen("tcp",":8040")
if err != nil {
log.Fatal(err)
}

    for {
            conn,err := listener.Accept()
            if err != nil {
                    log.Print(err) // e.g.,connection aborted
                    continue
            }   
            go handleConn(conn) //新建gorouti<a href="/tag/nes/" target="_blank" class="keywords">nes</a>处理连接
    }   

}

func handleConn(c net.Conn) {
input := bufio.NewScanner(c)
var wg sync.WaitGroup
//var ch =make(chan struct{})
for input.Scan() {
wg.Add(1)
go func(c net.Conn,shout string,delay time.Duration) {
defer wg.Done()
fmt.Fprintln(c,"\t",strings.toupper(shout))
time.Sleep(delay)
fmt.Fprintln(c,shout)
time.Sleep(delay)
fmt.Fprintln(c,strings.ToLower(shout))
//ch<-struct{}{}

            }(c,input.Text(),1*time.Second)
    }   
    wg.Wait()
            //cw := c.(*net.TCPConn)
      //cw.CloseWrite()

    c.Close()

}

  

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐