```go
listener, err := net.Listen("tcp", "127.0.0.1:7777")
checkError(err)
fmt.Println("建立成功!")
ch := make(chan string)
for {
//等待客户端接入
conn, err := listener.Accept()
....
```
我想在客户端建立连接的时候,把用户作为key,conn作为value,存在数据库或者redis里面,当想往某个用户发数据的时候,直接用户用户找到该用户的conn,如何实现呢
明白, 如果客户端或者服务器正常关闭,那么一定会更新外部的数据的,如果客户端不正常关闭,服务器端心跳机制也会去更新的, 我是这样计划的,你的意思conn可以存外部,怎么存,你觉得我上面那种外部+内部的方法可行不
#7
更多评论
问题还是有点意思的,可以考虑用 chan 来实现这个,下面是我写的代码,可以参考着写个更完善的。
``` go
package main
import (
"bufio"
"fmt"
"io"
"net"
"os"
)
func main() {
l, _ := net.Listen("tcp", ":8000")
for {
conn, _ := l.Accept()
ch := make(chan string)
go talk(conn, ch)
go input(ch)
}
}
func talk(conn io.ReadWriteCloser, ch chan string) {
for c := range ch {
fmt.Fprintf(conn, c)
}
fmt.Fprintf(conn, "closed, byebye.")
conn.Close()
}
func input(ch chan string) {
reader := bufio.NewReader(os.Stdin)
text, _ := reader.ReadString('\n')
for text != "#\n" {
ch <- text
text, _ = reader.ReadString('\n')
}
close(ch)
}
```
#2