我的GO版本是1.1.1
服务器在连接关闭后收到消息,但是没有设置延迟。
有什么不对吗
addr, _ := net.ResolveTCPAddr("tcp", "localhost:5432")
conn, err := net.DialTCP("tcp", nil, addr)
defer conn.Close()
if err != nil {
fmt.Println("connect fail")
return
}
err = conn.SetNoDelay(true)
if err != nil {
fmt.Println(err.Error())
}
for {
var message string
_, err := fmt.Scanln(&message)
if err != nil && err.Error() != "unexpected newline" {
fmt.Println("input finished", err)
break
}
if message == "" {
fmt.Println("no input, end")
break
}
// message = fmt.Sprintf("%s\n",message)
//fmt.Fprintf(conn, message) // send immediately but following message won't send any more
conn.Write([]byte(message)) // won't send until connection close
}
答案 0 :(得分:6)
您的代码似乎没有任何重大错误,因此我猜测错误发生在服务器端。
如果在端口5432上创建本地TCP服务器,则可以对此进行测试。
尝试运行以下服务器代码,然后针对它测试客户端代码。它只是将所有收到的数据发送到stdout。
package main
import (
"io"
"log"
"net"
"os"
)
func main() {
l, err := net.Listen("tcp", "localhost:5432")
if err != nil {
log.Fatal(err)
}
defer l.Close()
for {
conn, err := l.Accept()
if err != nil {
log.Fatal(err)
}
go func(c net.Conn) {
defer c.Close()
io.Copy(os.Stdout, c)
}(conn)
}
}
您应该在输入后立即看到发送给客户的每一行都打印出来(没有新行)。
答案 1 :(得分:1)
问题出在服务器端。
func handleConnection(conn net.Conn) {
// I didn't put it in for loop
message, err := bufio.NewReader(conn).ReadString('\n')
}