当前位置:首页 > 公众号精选 > 嵌入式云IOT技术圈
[导读]点击上方"嵌入式开发圈" 记得关注我们哦! 微信公众号:嵌入式开发圈 关注可了解更多的教程。问题或建议,请公众号留言; 如果你觉得本文对你有帮助,欢迎赞赏 如何对一个有规律的数组表进行位移          在嵌入式项目开发中,LED灯的操作是一定要会的,也是

点击上方"嵌入式开发圈" 记得关注我们哦!

微信公众号:嵌入式开发圈
关注可了解更多的教程。问题或建议,请公众号留言;
如果你觉得本文对你有帮助,欢迎赞赏

如何对一个有规律的数组表进行位移


    

    在嵌入式项目开发中,LED灯的操作是一定要会的,也是基础中的基础,比如用51单片机写个跑马灯,这不简单嘛,定义一个数组把那8个跑马灯存起来,然后搞个for循环不就可以了嘛,但是,实际工作开发中写一个跑马灯可不像学校和书本上那么简单噢,往往最简单的东西,有可能也是最复杂的。

   现在需求是这样的,要求实现以下形式的流水灯:跑马灯在这个表格中是一位一位进行存储的,如果要一行全亮,那么写0xff,灯就全亮了,写0x00,灯就全灭了。

    要求从led1流水到led100这个灯,如图所示,也就是实现100个灯的跑马灯操作。那如何实现呢?有人肯定会说定义十个数组就行啦,用填表的方法。然后搞十个for循环来实现,那么可取不?可取,但是太麻烦啦,因为这是用空间来换时间,虽然能达到效果,但是就太浪费内存空间了,效率也是很低的。

    那么如何快速处理这个问题呢?

    我们可以考虑位运算与循环的结合,首先思考一下,led是从第1个开始一直流到第100个,一共有十行,每行有十个,那么我们就可以定义一个for循环来循环相应的行数,设定led灯的初始位置,然后用移位算法,移动8位就换下一行,一个led相当于1bit,这样的话,两个for循环就可以搞定了,接下来我们用C语言来模拟这个过程。

 1void delay()  
2
{  
3    int i , j ;   
4    for(i = 0 ; i < 1000 ; i++)  
5        for(j = 0 ; j < 8000 ;j++);  
6}  
7//跑马灯从高位到低位流
8void test_low_to_high_bit()  
9
{  
10    int i , j ;   
11    int tick ;  
12    static int ledbuf[10] ;  
13    for(i = 0 ; i < 10 ; i++)  
14    {  
15    //设定每次开始的位置,从0x01开始
16        ledbuf[i] = 0x01 ;  
17        for(j = 0 ; j < 8 ; j++)  
18        {  
19            printf("%p ",ledbuf[i]); 
20            //每次左移一位,左移八次
21            ledbuf[i] <<= 1 ;   
22            delay() ;  
23        }  
24        putchar('\n');
25        //将数组清0,等待进入下一行
26        ledbuf[i] = 0 ;  
27    }  
28}  
29//跑马灯从低位到高位流
30void test_high_to_low_bit()  
31
{  
32    int i , j ;   
33    int tick ;  
34    static int ledbuf[10] ;  
35    for(i = 0 ; i < 10 ; i++)  
36    {  
37    //设定从高位的第一个LED灯的位置
38        ledbuf[i] = 0x80 ;  
39        for(j = 0 ; j < 8 ; j++)  
40        {  
41            printf("%p ",ledbuf[i]);  
42            //将数组的第一个元素右移一位,一共右移八位
43            ledbuf[i] >>= 1 ;  
44            delay() ;  
45        }  
46        putchar('\n');  
47        //将数组清0,等待进入下一行
48        ledbuf[i] = 0 ;
49    }  
50}  
51int main(void)  
52
{  
53    test_low_to_high_bit() ;  //测试从低位往高位输出
54    putchar('\n');  
55    test_high_to_low_bit() ;  //测试从高位往低位输出
56    return 0 ;  
57}  

运行结果:

    

     运行结果很明显,第一个是从第一位移位到第八位,移动了8次,移动了十行。第二个是反着来的,从高位到低位输出。   

     如果,现在有个需求改了,那个表中,我要指定的LED亮,其它的不亮,然后实现流水灯的效果,那要如何去写这个程序?

C语言之查表法项目运用

   

    

    面对一个无规律的数组表,假设这个数组表存放的是100个LED灯,一会想要一个个闪烁,一会想要一排排闪烁,一会乱序闪烁,那么,思考这样一个位移算法似乎是不可取的,所以,引入一个新的概念----查表法。

假设还是这么一张表,如图所示。存放着100个LED灯。

 1#include <stdio.h>
2#include <stdlib.h>
3#include <unistd.h>
4//这里的行可以自由写,这样就不受限制,想做出什么样的效果都可以。
5int array[][10] =  {  
6
7    0x03,0x00,0x00,0x00,0x00,//第一列
8    0x00,0x02,0x00,0x00,0x00,  
9
10    0x0C,0x00,0x00,0x00,0x00,//第二列
11    0x00,0x04,0x00,0x00,0x00,  
12
13    0x10,0x00,0x00,0x00,0x00,//第三列
14    0x00,0x08,0x00,0x00,0x00,  
15
16    0x60,0x00,0x00,0x00,0x00,//第四列
17    0x00,0x10,0x00,0x00,0x00,  
18
19    0x80,0x01,0x00,0x00,0x00,//第五列
20    0x00,0x20,0x00,0x00,0x00,  
21//多写一行,用来标志结束
22    0xAA,0x55,0x00,0x00,0xC0,//end  
23    0x00,0x00,0x00,0x00,0x00,  
24
25};  
26//输出表中的数据
27void Print_led(int *array)  
28
{  
29    int i;  
30    for(i = 0; i < 10; i++)  
31    {  
32    printf("%3x", *(array+i));
33    }  
34    printf("\n");  
35}  
36
37//延时函数
38void delay_500ms(void)  
39
{  
40    usleep(500000);  
41}  
42
43int main(void)  
44
{  
45    int i,j;  
46    int tick;  
47    int count = 0
48    //如果当数组第count行第0列等于0xAA,或者第count行第1列等于0x55时
49 //那么就退出,否则就循环执行遍历数据
50    while(array[count][0] != 0xAA || array[count][1] != 0x55
51    {  
52        //以首元素每次向后偏移10个字节
53        Print_led((int *)(&array[0][0]+count*10) );
54        delay_500ms();  
55        count++;  
56    }  
57    return 0;  
58}  

运行结果:

  

    这样,只需要往表里填想要输出的数据,就可以成功输出了,这种方法就是以空间换时间的查表法,是嵌入式开发中最常用也是最实用的方法,这种方法对于算法掌握不是特别熟练的工程师来说是一种偷懒的办法。

韦东山嵌入式学习视频推荐

    韦东山老师优质嵌入式学习干货推荐:包括ARM裸机开发、Linux设备驱动程序、Linux应用程序开发、Android系统学习、Linux设备树等。

也可直接扫码淘宝购买




长期合作服务

深圳广志创新科技有限公司

业务范围:单片机软件开发、项目工程开发、硬件电路设计、元器件供应。本公司拥有智能家居,智能消防,消费类电子(移动电源、风扇、玩具、广告灯、加湿器等)等成熟开发方案。使用MCU范围:8位单片机,32位单片机。

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭