微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 单片机C语言移位的实现

单片机C语言移位的实现

时间:11-18 来源:互联网 点击:

流水灯循环左移右移,用C语言,要高效的话,只有用伪本征函数文件“intrins.h”中的_crol_(),_cror_()...等等函数,具体解释如蓝色文字,例如,要用P1口驱动8个共阳连接的二极管左循环一个一个地亮,语句是 P1=_crol_(a,1);//a储存被移位的字符。

c51中的intrins.h库函数

_crol_ 字符循环左移

_cror_ 字符循环右移

_irol_ 整数循环左移

_iror_ 整数循环右移

_lrol_ 长整数循环左移

_lror_ 长整数循环右移

_nop_ 空操作8051 NOP 指令

_testbit_ 测试并清零位8051JBC 指令

详解:

函数名: _crol_,_irol_,_lrol_

原 型: unsigned char _crol_(unsigned char val,unsigned char n);

unsigned int _irol_(unsigned int val,unsigned char n);

unsigned int _lrol_(unsigned int val,unsigned char n);

功 能:_crol_,_irol_,_lrol_以位形式将val左移n 位,环移(左端移出的填补右端的空位),该函数与8051“RL A”指令相关,上面几个函数不同于参数类型。(调用“一次”这样的函数把val环移n位,所谓的循环移位并不是持续的一直移位下去,要想得到这样的效果,外部须加上循环语句实现)。

例:

#include

main()

{

unsigned int y;

C-5 1 程序设计 37

y=0x00ff;

y=_irol_(y,4); /*y=0x0ff0*/

}

函数名: _cror_,_iror_,_lror_

原 型: unsigned char _cror_(unsigned char val,unsigned char n);

unsigned int _iror_(unsigned int val,unsigned char n);

unsigned int _lror_(unsigned int val,unsigned char n);

功 能:_cror_,_iror_,_lror_以位形式将val右移n 位,环移,该函数与8051“RR A”指令相关,上面几个函数不同于参数类型。

例:

#include

main()

{

unsigned int y;

y=0x0ff00;

y=_iror_(y,4); /*y=0x0ff0*/

}

函数名: _nop_

原 型: void _nop_(void);

功 能:_nop_产生一个NOP 指令,该函数可用作C程序的时间比较。C51 编译器在_nop_

函数工作期间不产生函数调用,即在程序中直接执行了NOP 指令。

例:

P()=1;

_nop_();

P()=0;

函数名: _testbit_

原 型:bit _testbit_(bit x);

功 能:_testbit_产生一个JBC 指令,该函数测试一个位,当置位时返回1,否则返回0。

如果该位置为1,则将该位复位为0。8051 的JBC 指令即用作此目的。

_testbit_只能用于可直接寻址的位;在表达式中使用是不允许的。

至于>>=,>>,<,<=的移位运算符,不要天真以为它会循环移位,事实上,一个8位的字符,左移一位之后,最右边一位变成0了,而非原来最左边的一位。如果左移8位,就意味着这个8位的字符变成0x00了。具体的,如果用C实现循环移位呢?
div:eq(0) > div:eq(3) > table:eq(2) > tbody:eq(0) > tr:eq(0) > td:eq(0) > div:eq(0) > #content:eq(0) > br:eq(2)" anchortype="previous" jquery1249565275578="8">思路是:

比如将a=0x45循环左移二位。

a循环左移n位,即将原来右面(8-n)位左移n位,而将原来左端的n位移到最右面n位。

1、将a的左端n位先放到b中的低n位中

b=a>>(8-n);

2、将a左移n位,其右面低n位被补0

c=a

3、将b,c进行或运算

a=c|b;

程序如下:

main()

{

unsigned char a=0x45,b,c;

unsigned int n=2;

b=a>>(8-n)

c=a

a=c|b;

}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top