Go语言实现长连接并发框架 - 消息

文章目录

前言

你好,我是醉墨居士,上篇博客实现了对连接的封装,那我们对连接的读写操作涉及数据格式的定义,我们采用统一的数据格式。使用我们这种数据格式的数据,我们将其称之为消息

接口

trait/message.go

go 复制代码
type Message interface {
	ID() uint16
	DataLen() uint16
	Data() []byte

	SetID(uint16)
	SetDataLen(uint16)
	SetData([]byte)
}

结构体

gpack/message.go

go 复制代码
// Message 业务消息
type Message struct {
	//消息ID
	id uint16
	//消息的长度
	dataLen uint16
	//消息的内容
	data []byte
}

// 创建一个message
func NewMessage(id uint16, data []byte) *Message {
	return &Message{
		id:      id,
		dataLen: uint16(len(data)),
		data:    data,
	}
}

接口实现

gpack/message.go

go 复制代码
// ID 返回消息ID
func (m *Message) ID() uint16 {
	return m.id
}

// DataLen 返回消息体的长度
func (m *Message) DataLen() uint16 {
	return m.dataLen
}

// Data 返回消息的内容
func (m *Message) Data() []byte {
	return m.data
}

// SetID 设置消息ID
func (m *Message) SetID(id uint16) {
	m.id = id
}

// SetDataLen 设置消息体的长度
func (m *Message) SetDataLen(dataLen uint16) {
	m.dataLen = dataLen
}

// SetData 设置消息的内容
func (m *Message) SetData(data []byte) {
	m.data = data
}

项目地址

Github:https://github.com/zm50/gte

Giee:https://gitee.com/zm50/gte

最后

我是醉墨居士,我们完成了框架内部连接中的数据传输中数据格式的消息定义,后续我们可以基于这个消息进行相关连接数据读取,消息封装,消息分发等步骤的处理

相关推荐
路由侠内网穿透5 分钟前
本地部署开源工作空间工具 AFFiNE 并实现外部访问
运维·服务器·数据库·物联网·开源
zzzsde7 分钟前
【Linux】Ext文件系统(1)
linux·运维·服务器
程途知微9 分钟前
AQS 同步器——Java 并发框架的核心底座全解析
java·后端
爱学习的小囧10 分钟前
ESXi 8.0 无法选择分区方式 小白级详细解决办法
运维·服务器·网络·虚拟化·esxi8.0
froginwe1114 分钟前
Bootstrap4 折叠组件使用指南
开发语言
sunwenjian88615 分钟前
SpringBean的生命周期
java·开发语言
毕设源码-赖学姐36 分钟前
【开题答辩全过程】以 基于Java的游泳馆会员管理系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
iPadiPhone44 分钟前
分布式架构的“润滑剂”:RabbitMQ 核心原理与大厂面试避坑指南
分布式·后端·面试·架构·rabbitmq
xlq223221 小时前
34 信号
linux
徐子元竟然被占了!!1 小时前
批处理脚本-命令
服务器