
做通讯程序,我认为以下几点至关重要:
1、首先要了解通讯规约。
2、了解硬件接口的定义、用什么样的通讯电缆、如何制作通讯电缆等,这很重要,硬件要是做得不对,做其它的等于耽误工夫,还可能会烧设备。
3、告诉主站你的从站的站号(站地址),波特率等参数的设置,这样才能建立通讯连接。
4、然后就是发送/接收功能块,功能块都有相应的说明。
5、虽然说通讯是靠硬件靠程序实现的,但通讯的数据来源、去向,数据多少,格式,代表的内容这些东西可都是事先已在编程者的脑子中的。
6、MODBUS通讯用modscan先调试一下很有必要,这样至少可以先保证一方是对的,有利于问题的排查。你所读到的地址,所用的功能码等在测试软件里都能看到。
data ;
littleEndian BYTE 12h,34h,56h,78h
code
main PROC
MOV EAX,offset littleEndian
MOV BH,[EAX+0]
MOV BL,[EAX+3]
mov [EAX+3],BH
mov [EAX+0],BL
MOV BH,[EAX+2]
MOV BL,[EAX+1]
mov [EAX+1],BH
mov [EAX+2],BL
加3g实验室的艰难之旅,遇到一道这样的实验室面试题:
输出结果为2000000
原题对a强制转换为int,64位机指针长度为八个字节,所以改为long int。
先来分析一下表达式,a为数组a[0]的地址,强制转换为长整型变为地址的数值后加一,实际为第一个元素的第二字节地址的数值。后转换为一指向整型的指针并赋值给ptr2。整型为4个字节,从第一元素第二字节开始往后读取四个字节,间接访问得出此四个字节代表的数值,并以十六进制输出。
那么问题来了,为什么是2000000,数组的整型元素在内存中是怎么储存的?这四个字节内存的是怎样的二进制数?为什么会这样储存?
经过度娘的帮助,它终于出现了—— 大小端模式 。
大端模式
大端模式是指数据的高位,保存在内存的低地址中,而数据的低位,保存在内存的高地址中。大端模式与我们的阅读习惯相同。
小端模式
小端模式是指数据的高位保存在内存的高地址中,而数据的低位保存在内存的低地址中。
举例
int a=2;
地址:小----->大
在大端模式中,a存为:
0x00 0x00 0x00 0x02
在小端模式中,a存为:
0x02 0x00 0x00 0x00
在计算机系统中,地址是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了一个字节(8bit)的char之外,还有两个字节(16bit)的short型等超过一个字节的数据类型。另外,对于位数大于 8位的处理器,由于寄存器宽度大于一个字节。所以必然存在如何将多个字节安排的问题,因此就有了大端存储模式和小端存储模式。
小说《格列夫游记》中,小人国内部分裂成Big-endian和Little-endian两派,区别在于一派要求从鸡蛋的大头把鸡蛋打破,另一派要求从鸡蛋的小头把鸡蛋打破。斯威夫特借以讽刺英国的政党之争,在计算机工业中指数据储存顺序的分歧。
一个简单的判断数据储存模式为大端模式还是小端模式。
a[5] = {1,2,3,4,5};
第一个元素和第二个元素储存方式
(地址:小--->大)
大端模式下:
0x00 0x00 0x00 0x01 0x00 0x00 0x00 0x02
小端模式下:
0x01 0x00 0x00 0x00 0x02 0x00 0x00 0x00
截取第二个字节到第五个字节
大端模式:
0x00 0x00 0x01 0x00
小端模式:
0x00 0x00 0x00 0x02
读取数据
大端模式:
从高地址往低地址读取
0x00 0x00 0x01 0x00
读取数据转换为十六进制为100
小端模式:
从低地址往高地址读取
0x00 0x00 0x00 0x02
排成大端(0x02 0x00 0x00 0x00)
读取数据转换为十六进制为2000000
所以在大端模式下,结果为100。
在小端模式下,结果为2000000。
学C学得好迷啊,心好累,哈哈哈哈哈。
一、定义:
大端模式(Big Endian):数据的高字节,保存在内存的低地址中;数据的低字节,保存在内存的高地址中。
小端模式(Little Endian):数据的高字节,保存在内存的高地址中;数据的低字节,保存在内存的低地址中。
例如:数字0x12 34 56 78在内存中的表示形式为:
1)大端模式:
低地址 -----------------> 高地址
0x12 | 0x34 | 0x56 | 0x78
2)小端模式:
低地址 ------------------> 高地址
0x78 | 0x56 | 0x34 | 0x12
可见,大端模式和字符串的存储模式类似。
二、如何判断机器的字节序
通过将int强制类型转换成char单字节,通过判断起始存储位置。即等于 取b等于a的低地址部分
联合体union的存放顺序是所有成员都从低地址开始存放,利用该特性可以轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写
三、网络字节序
网络上传输的数据都是字节流,对于一个多字节数值,在进行网络传输的时候,先传递哪个字节也就是说,当接收端收到第一个字节的时候,它将这个字节作为高位字节还是低位字节处理,是一个比较有意义的问题; UDP/TCP/IP协议规定:把接收到的第一个字节当作高位字节看待,这就要求发送端发送的第一个字节是高位字节;而在发送端发送数据时,发送的第一个字节是该数值在内存中的起始地址处对应的那个字节,也就是说,该数值在内存中的起始地址处对应的那个字节就是要发送的第一个高位字节(即:高位字节存放在低地址处);由此可见,多字节数值在发送之前,在内存中因该是以大端法存放的; 所以说,网络字节序是大端字节序; 在实际中,当在两个存储方式不同的主机上传输时,需要借助字节序转换函数。
以上就是关于Deltav,DCS通讯modbus怎么设置大端小端全部的内容,包括:Deltav,DCS通讯modbus怎么设置大端小端、汇编语言程序设计题--编程实现将X86采用的小端模式转换成大端模式、大小端模式等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)