在此之前,先了解一下defer
这篇文章通过几个生动的例子阐述了go语言当中return的执行顺序和原理,也解答了为什么defer明明执行在return之前,但是看起来却是在return之后进行的
然后,写两个简单的服务端和客户端的例子
package main
import (
"net"
"fmt"
)
func main() {
var os int
fmt.Println("请输入服务端或客户端编号")
fmt.Scan(&os)
if os == 1 {
server, err := net.Listen("tcp", ":8888")
if err == nil { //若果err为nil,则成功创建
for {
con, error_ := server.Accept()
fmt.Println("有一个客户连接\n")
if error_ == nil {
con.Write([]byte("hello world!"))
}
}
} else {
return
}
} else {
conn, err := net.Dial("tcp", "127.0.0.1:8888")
if err == nil {
for {
buf := make([]byte, 1024)
if length, err := conn.Read(buf); err == nil {
if length > 0 {
buf[length] = 0
fmt.Printf("%s", string(buf[0:length]))
}
}
}
} else {
return
}
}
}
再打开服务端的情况下,我们打开一个客户端就会如下显示
小测试之后,有一篇文章写的很好
GO语言的进阶之路-网络编程之socket
膜拜大神,很详细很清楚,还有完整的例子