流水燈循環(huán)左移右移,用C語言,要高效的話,只有用偽本征函數(shù)文件“intrins.h”中的_crol_(),_cror_()...等等函數(shù),具體解釋如藍色文字,例如,要用P1口驅(qū)動8個共陽連接的二極管左循環(huán)一個一個地亮,語句是 P1=_crol_(a,1);//a儲存被移位的字符。
本文引用地址:http://cafeforensic.com/article/201611/315732.htmc51中的intrins.h庫函數(shù)
_crol_ 字符循環(huán)左移
_cror_ 字符循環(huán)右移
_irol_ 整數(shù)循環(huán)左移
_iror_ 整數(shù)循環(huán)右移
_lrol_ 長整數(shù)循環(huán)左移
_lror_ 長整數(shù)循環(huán)右移
_nop_ 空操作8051 NOP 指令
_testbit_ 測試并清零位8051JBC 指令
詳解:
函數(shù)名: _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 位,環(huán)移(左端移出的填補右端的空位),該函數(shù)與8051“RL A”指令相關(guān),上面幾個函數(shù)不同于參數(shù)類型。(調(diào)用“一次”這樣的函數(shù)把val環(huán)移n位,所謂的循環(huán)移位并不是持續(xù)的一直移位下去,要想得到這樣的效果,外部須加上循環(huán)語句實現(xiàn))。
例:
#include
main()
{
unsigned int y;
C-5 1 程序設計 37
y=0x00ff;
y=_irol_(y,4); /*y=0x0ff0*/
}
函數(shù)名: _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 位,環(huán)移,該函數(shù)與8051“RR A”指令相關(guān),上面幾個函數(shù)不同于參數(shù)類型。
例:
#include
main()
{
unsigned int y;
y=0x0ff00;
y=_iror_(y,4); /*y=0x0ff0*/
}
函數(shù)名: _nop_
原 型: void _nop_(void);
功 能:_nop_產(chǎn)生一個NOP 指令,該函數(shù)可用作C程序的時間比較。C51 編譯器在_nop_
函數(shù)工作期間不產(chǎn)生函數(shù)調(diào)用,即在程序中直接執(zhí)行了NOP 指令。
例:
P()=1;
_nop_();
P()=0;
函數(shù)名: _testbit_
原 型:bit _testbit_(bit x);
功 能:_testbit_產(chǎn)生一個JBC 指令,該函數(shù)測試一個位,當置位時返回1,否則返回0。
如果該位置為1,則將該位復位為0。8051 的JBC 指令即用作此目的。
_testbit_只能用于可直接尋址的位;在表達式中使用是不允許的。
至于>>=,>>,<<,<<=的移位運算符,不要天真以為它會循環(huán)移位,事實上,一個8位的字符,左移一位之后,最右邊一位變成0了,而非原來最左邊的一位。如果左移8位,就意味著這個8位的字符變成0x00了。具體的,如果用C實現(xiàn)循環(huán)移位呢?
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循環(huán)左移二位。
a循環(huán)左移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;
}
評論