Golang TCP客户端实现菜单显示,实现广播聊天

 

通过嵌套循环实现用户选择操作

fmt.Println("1.公聊模式")
	fmt.Println("2.私聊模式")
	fmt.Println("3.修改用户名")
	fmt.Println("4.退出")

	var flag int

	fmt.Scanln(&flag)

	for  {
		switch flag {
		case 1:
			println("输入发送内容,发送end 回到上级目录")
			var msg  string
			fmt.Scanln(&msg)
			for msg != "end" {
				client.brodCast(msg)
				fmt.Scanln(&msg)
			}
		case 2:
			println("2")
		case 3:
			println("3")
		case 4:
			println("exit")
			os.Exit(1)
		default:
			println("input invalid")

		}

		fmt.Println("1.公聊模式")
		fmt.Println("2.私聊模式")
		fmt.Println("3.修改用户名")
		fmt.Println("4.退出")
		fmt.Scanln(&flag)
	}

 

创建协程用于接收服务器来的消息,同时用接收数据为0来判断服务器是否断开

func (this* Client) tcpListener()  {
	for  {
		msg :=make([]byte,4096)
		num,err :=this.Conn.Read(msg)
		if err != nil {
			fmt.Println("user Read err:",err)
		}

		if num==0 {
			fmt.Println(fmt.Sprintf("server:%s device close.",this.Conn.RemoteAddr().String()))
			_ = this.Conn.Close()
			runtime.Goexit()
		}else {
			msgStr := string(msg[:num])
			fmt.Println(msgStr)
		}
	}
}

根据与服务器的协议,发送广播消息

 

func (this* Client) brodCast(msg string)  {
	_,err := this.Conn.Write([]byte("all:"+msg))
	if err != nil {
		fmt.Println("server brodCast err:",err)
	}
}

 

效果:

 

目录:

Golang 从入门到放弃

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Golang 提供了一组标准库,用于实现大文件传输。下面是一个使用TCP连接传输文件的示例代码:package mainimport ( "fmt" "io" "net" "os" )func main() { // 建立TCP连接 conn, err := net.Dial("tcp", "127.0.0.1:8080") if err != nil { fmt.Println("Error dialing", err.Error()) return } // 打开要传输的文件 file, err := os.Open("test.txt") if err != nil { fmt.Println("Error openning file", err.Error()) return } // 将文件内容传输给服务端 _, err = io.Copy(conn, file) if err != nil { fmt.Println("Error sending file", err.Error()) return } fmt.Println("File sent successfully") } ### 回答2: 下面是使用golang通过TCP实现大文件传输的示例代码: ```go package main import ( "fmt" "io" "log" "net" "os" ) const ( concurrentConnections = 5 // 并发连接数 chunkSize = 1024 // 每个数据块的大小 ) func main() { listener, err := net.Listen("tcp", ":8080") // 监听端口8080 if err != nil { log.Fatal(err) } defer listener.Close() for { conn, err := listener.Accept() // 接受客户端连接 if err != nil { log.Fatal(err) } go handleConnection(conn) // 开始一个新的goroutine处理客户端连接 } } // 处理连接 func handleConnection(conn net.Conn) { defer conn.Close() // 读取文件名信息 fileName := make([]byte, 64) _, err := conn.Read(fileName) if err != nil { log.Println("Failed to read file name:", err) return } file, err := os.Create(string(fileName)) // 创建文件 if err != nil { log.Println("Failed to create file:", err) return } defer file.Close() // 从连接中读取数据并写入文件 var receivedBytes int64 for { buffer := make([]byte, chunkSize) n, err := conn.Read(buffer) if err != nil { if err != io.EOF { log.Println("Failed to read data:", err) } break } receivedBytes += int64(n) file.Write(buffer[:n]) if receivedBytes >= fileStat.Size() { break } } fmt.Println("File received:", file.Name()) } ``` 这个示例中通过TCP接受客户端连接,并读取客户端传输的文件名信息。然后创建文件并持续从连接中读取数据块并写入文件,直到接收完整个文件。最后打印出文件的名称。代码中使用了并发连接数和每个数据块的大小来处理大文件传输,提高了传输速度和效率。需要注意的是,需要根据实际情况调整并发连接数和数据块大小。 ### 回答3: 下面是一个使用golang通过TCP实现大文件传输的示例代码: ``` package main import ( "fmt" "io" "net" "os" ) func main() { // 设置TCP服务器的地址和端口 serverAddr := "127.0.0.1:8080" // 打开本地文件 file, err := os.Open("bigfile.txt") if err != nil { fmt.Println("无法打开文件:", err) return } defer file.Close() // 连接到TCP服务器 conn, err := net.Dial("tcp", serverAddr) if err != nil { fmt.Println("无法连接到服务器:", err) return } defer conn.Close() // 从本地文件读取数据并发送到服务器 buf := make([]byte, 1024) for { n, err := file.Read(buf) if err != nil { if err == io.EOF { break } fmt.Println("读取文件出错:", err) return } // 发送数据到服务器 _, err = conn.Write(buf[:n]) if err != nil { fmt.Println("发送数据到服务器出错:", err) return } } fmt.Println("文件传输完成") } ``` 这个示例代码假设你的大文件是`bigfile.txt`,它会打开该文件并连接到TCP服务器的地址`127.0.0.1:8080`。然后,它会读取文件的数据块,并将其发送到服务器。重复这个过程,直到文件读取完毕。最后,它会输出"文件传输完成"。注意,你需要在服务器端实现相应的代码来接收这些数据块,并将其写入到文件中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值