Go语言的Socket编程实现为开发者提供了一种高效且强大的方式来实现网络通信。通过Go语言的并发模型和内置的网络库,如net
包,开发者可以轻松地创建基于套接字的通信应用。Go语言的goroutine和channel机制使并发处理变得简单,能够轻松处理多个连接和数据交换。使用Go语言进行Socket编程,开发者可以初始化和监听端口,接受连接请求,建立直接的点对点通信通道,并在不同节点之间进行数据传输。这种方式使得开发者能够构建出鲁棒、高性能的P2P通信应用,同时充分利用了Go语言在并发编程方面的优势。
“P2P”代表“点对点”(Peer-to-Peer)的缩写,它是一种网络通信和数据共享模式。在传统的客户端–服务器模型中,计算机系统(客户端)通过向中央服务器请求数据来进行通信和数据交换。而在P2P模型中,计算机之间可以直接相互连接,共享资源和信息,而无需依赖一个中央服务器。
package main
import (
"bufio"
"fmt"
"net"
"os"
)
func handleIncomingMessages(conn net.Conn) {
scanner := bufio.NewScanner(conn)
for scanner.Scan() {
text := scanner.Text()
fmt.Printf("Received from Player 2: %sn", text)
}
}
func main() {
// player1做服务端监听
listener, _ := net.Listen("tcp", "127.0.0.1:9001")
defer listener.Close()
fmt.Println("Player 1 waiting for a match on 127.0.0.1:9001")
conn, _ := listener.Accept()
defer conn.Close()
fmt.Println("Player 1 connected to Player 2")
// player1的接收
go handleIncomingMessages(conn)
// player1的发送
scanner := bufio.NewScanner(os.Stdin)
for scanner.Scan() {
text := scanner.Text()
fmt.Fprintf(conn, "%sn", text)
}
}
package main
import (
"bufio"
"fmt"
"net"
"os"
)
func handleIncomingMessages(conn net.Conn) {
scanner := bufio.NewScanner(conn)
for scanner.Scan() {
text := scanner.Text()
fmt.Printf("Received from Player 1: %sn", text)
}
}
func main() {
// player2做客户端连接服务端
conn, _ := net.Dial("tcp", "127.0.0.1:9001")
defer conn.Close()
fmt.Println("Player 2 connected to Player 1")
// player2的接收
go handleIncomingMessages(conn)
// player2的发送
scanner := bufio.NewScanner(os.Stdin)
for scanner.Scan() {
text := scanner.Text()
fmt.Fprintf(conn, "%sn", text)
}
}
for scanner.Scan() {
text := scanner.Text()
fmt.Fprintf(conn, "%sn", text)
}
}
原文地址:https://blog.csdn.net/qq_22328011/article/details/132427452
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_47128.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。