【Go语言】基于Socket编程的P2P通信程序示例

Go语言的Socket编程实现为开发者提供了一种高效且强大的方式来实现网络通信。通过Go语言的并发模型和内置的网络库,如net包,开发者可以轻松地创建基于套接字的通信应用。Go语言的goroutine和channel机制使并发处理变得简单,能够轻松处理多个连接和数据交换。使用Go语言进行Socket编程,开发者可以初始化和监听端口,接受连接请求,建立直接的点对点通信通道,并在不同节点之间进行数据传输。这种方式使得开发者能够构建出鲁棒、高性能的P2P通信应用,同时充分利用了Go语言在并发编程方面的优势。

"P2P"代表"点对点"(Peer-to-Peer)的缩写,它是一种网络通信和数据共享模式。在传统的客户端-服务器模型中,计算机系统(客户端)通过向中央服务器请求数据来进行通信和数据交换。而在P2P模型中,计算机之间可以直接相互连接,共享资源和信息,而无需依赖一个中央服务器。

player1.go

go 复制代码
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: %s\n", 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, "%s\n", text)
	}
}

player2.go

go 复制代码
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: %s\n", 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, "%s\n", text)
	}
}
for scanner.Scan() {
		text := scanner.Text()
		fmt.Fprintf(conn, "%s\n", text)
	}
}
相关推荐
何以解忧,唯有..15 天前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
踏着七彩祥云的小丑15 天前
Go学习第9天:并发编程 + 文件操作 + 正则表达式
学习·golang·正则表达式·go
JCGKS15 天前
Go `init` 函数:包初始化顺序到底是怎样的
golang·init·init执行顺序
何以解忧,唯有..15 天前
Go语言中的const:常量声明与iota枚举详解
java·开发语言·golang
terry60015 天前
5G视频短信服务商选型全攻略:通道资源、架构能力与成本评估2026最新标准
大数据·人工智能·5g·json·asp.net·信息与通信·数据库架构
geovindu15 天前
go: Reactor Pattern
开发语言·后端·设计模式·golang·反应器模式
勇敢牛牛_15 天前
Zeplyn:通过P2P构建服务共享网络
网络·网络协议·p2p·服务
記億揺晃着的那天15 天前
Java 调用外部 Go 程序的实践:ProcessBuilder 在生产环境中的应用
java·golang·processbuilder
jingling55516 天前
go | 环境安装和快速入门
开发语言·后端·golang
java_cj16 天前
从kubectl学Visitor模式:如何优雅处理多态数据结构的遍历
云原生·golang·k8s·访问者模式