当前位置: 代码网 > it编程>编程语言>Asp.net > c# modbus大小端的使用小结

c# modbus大小端的使用小结

2026年03月25日 Asp.net 我要评论
一、先统一核心概念:大小端的本质无论 modbus 还是计算机,大小端的定义是完全相同的,核心是多字节数据的字节排列顺序:大端序(big-endian):高字节(数值权重高的字节)存放在低地址,低字节

一、先统一核心概念:大小端的本质

无论 modbus 还是计算机,大小端的定义是完全相同的,核心是多字节数据的字节排列顺序:

  • 大端序(big-endian):高字节(数值权重高的字节)存放在低地址,低字节存放在高地址(“高位在前”)。
  • 小端序(little-endian):低字节存放在低地址,高字节存放在高地址(“低位在前”)。

举个例子:数值 0x1234(十进制 4660),2 个字节的排列:

类型内存 / 传输顺序(低地址→高地址)通俗理解
大端序0x12 → 0x34先写高位,后写低位
小端序0x34 → 0x12先写低位,后写高位

二、modbus 与计算机大小端的核心差异

对比维度modbus 协议计算机(cpu / 系统)
默认规则强制推荐 / 标准是大端序(无例外)绝大多数是小端序(x86/x86_64 架构,如 intel/amd cpu);少数大端(如 powerpc、sparc)
应用范围仅作用于寄存器数据传输 / 存储:1. 单个 16 位寄存器内的字节排列2. 32 位数据跨多个寄存器的字序作用于内存中所有多字节数据:1. 变量存储(如 int、float)2. 文件 / 网络传输前的原生排列
灵活性部分非标设备会自定义为小端序(需适配)系统级固定,开发者无法修改(只能手动转换)

三、实战举例:为什么会感觉 “不同”?

以你之前的需求为例:要把计算机里的数值 18(0x0012)写入 modbus 寄存器,直观体现差异:

1. 计算机(小端)的原生存储

数值 0x0012 在 x86 计算机内存中存储顺序是:0x12(低字节)→ 0x00(高字节)。

2. modbus(大端)的传输要求

modbus 寄存器要求传输顺序是:0x00(高字节)→ 0x12(低字节)。

3. 必须做的转换(代码层面)

如果直接把计算机的原生字节传给 modbus,数值会变成 0x1200(十进制 4608),完全错误!因此需要手动反转字节:

运行

// 计算机小端 → modbus 大端 转换示例
ushort value = 18; // 0x0012,计算机原生存储为 0x12 0x00
ushort modbusvalue = (ushort)(((value & 0xff) << 8) | ((value & 0xff00) >> 8));
// 转换后 modbusvalue = 0x0012(传输顺序 0x00 → 0x12),符合 modbus 要求

四、关键补充:32 位数据的 “双重差异”

对于 32 位浮点数(如 25.5),差异会叠加:

  1. 计算机小端:浮点数 25.5 转字节是 0x00 0x00 0x20 0x41(原生小端);
  2. modbus 大端:需先反转整个 4 字节为大端(0x41 0x20 0x00 0x00),再拆分为 2 个 16 位寄存器(0x4120、0x0000),按 “高字在前” 传输。

总结

  1. 大小端的定义本身相同,差异在于 modbus 强制用大端,而主流计算机默认用小端;
  2. 开发中核心工作是把计算机小端的字节序转换为 modbus 要求的大端序(少数设备需转小端);
  3. 无需纠结 “是否不同”,只需记住:读取 modbus 数据后要转成计算机小端,写入前要转成 modbus 要求的字节序。

简单来说:modbus 是 “规矩固定的外部设备”,计算机是 “习惯不同的内部系统”,你作为开发者只需要做好两者之间的 “翻译” 即可。

到此这篇关于c# modbus大小端的使用小结的文章就介绍到这了,更多相关c# modbus大小端内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com