程序两种写法

[复制链接]
 楼主| huanghuac 发表于 2011-2-23 14:47 | 显示全部楼层 |阅读模式
编译后那个效率高些
#define INT8U REG_T

INT16U m_data

push_to_buf(*(((REG_T*)&m_data)++));

push_to_buf((REG_T)(m_data<<8));

把m_data,放到一个REG_T的数组内;
happy_10 发表于 2011-2-23 15:15 | 显示全部楼层
第一种移植吧
duanchongbo1 发表于 2011-2-23 15:17 | 显示全部楼层
不懂
冰清玉洁 发表于 2011-2-23 15:37 | 显示全部楼层
都不好,为什么要入栈呢
wenfen 发表于 2011-2-23 15:43 | 显示全部楼层
是啊,在C语言中不要去操纵堆栈
tian111 发表于 2011-2-23 15:56 | 显示全部楼层
直接改汇编操作,并且这部分代码也必须用汇编
 楼主| huanghuac 发表于 2011-2-23 16:23 | 显示全部楼层
push 是个函数,不是指令,现在改成push_to_buf();
zhuhuis 发表于 2011-2-23 16:26 | 显示全部楼层
第二个应该是push_to_buf((REG_T)(m_data>>8));
一个做加法运算,一个做移位运算,看起来第一个效率要高些,但实际上可能并不如此。
chenho 发表于 2011-2-23 16:30 | 显示全部楼层
如果m_data是局部变量,第一种写法要求m_data不能放在寄存器中,第二个的m_data则可以放在寄存器,寄存器访问要比内存访问快很多。
zhuhuis 发表于 2011-2-23 17:37 | 显示全部楼层
是的,如果所用的cpu支持多位移位运算,两者的效率不会有太大的区别,但第二种更安全。
 楼主| huanghuac 发表于 2011-2-23 17:44 | 显示全部楼层
push_to_buf((REG_T)(m_data>>8));是把m_data的低字节压上去这是大端还是说小端?
 楼主| huanghuac 发表于 2011-2-23 17:45 | 显示全部楼层
push_to_buf((REG_T)m_data);在大端模式下是把高字节压上去还是低字节压上去?
chenho 发表于 2011-2-23 18:01 | 显示全部楼层
我觉得你的REG_T一般来说是指寄存器类型,也就是说几位机,而第2种好像只能在8位机下工作。
宋倩2010 发表于 2011-2-23 18:03 | 显示全部楼层
第一种才要考虑大端小端的问题。
wenfen 发表于 2011-2-23 18:31 | 显示全部楼层
大端情况下,push_to_buf(*(((REG_T*)&m_data)++));压入的是低字节,小端情况下,压入的是高字节。
宋倩2010 发表于 2011-2-23 18:33 | 显示全部楼层
是啊,你这些在8位机下讨论才有意义。
wenfen 发表于 2011-2-23 18:44 | 显示全部楼层
如果REG_T是int(16位或32位),push_to_buf(*(((REG_T*)&m_data)++));压入的不是m_data的低字节也不是m_data的高字节,而是与m_data相邻的int。
 楼主| huanghuac 发表于 2011-2-23 18:59 | 显示全部楼层
OK,知道了,结贴
linqing171 发表于 2011-2-23 21:33 | 显示全部楼层
1# huanghuac

两个变异后,结果是一样的,都是直接地址访问了一个字节,然后放入通用寄存器,然后调用函数.
keil 4环境.
linqing171 发表于 2011-2-23 21:37 | 显示全部楼层
我师父喜欢这样写:
push_to_buf((((REG_T*)&m_data)[1]));
您需要登录后才可以回帖 登录 | 注册

本版积分规则

772

主题

8473

帖子

6

粉丝
快速回复 在线客服 返回列表 返回顶部