嵌入式C实战项目开发技巧:对一个有规律的数组表进行位移操作的方法

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

跑马灯在这个表格中是一位一位进行存储的,如果要一行全亮,那么写0xff,灯就全亮了,写0x00,灯就全灭了。

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

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

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

#include <stdio.h>
void delay()
{
 int i , j ;
 for(i = 0 ; i < 1000 ; i++)
 for(j = 0 ; j < 8000 ;j++);
}
//跑马灯从高位到低位流
void test_low_to_high_bit()
{
 int i , j ;
 int tick ;
 static int ledbuf[10] ;
 for(i = 0 ; i < 10 ; i++)
 {
 ledbuf[i] = 0x01 ; //设定每次开始的位置,从0x01开始
 for(j = 0 ; j < 8 ; j++)
 {
  printf("%p ",ledbuf[i]);
  ledbuf[i] <<= 1 ; //每次左移一位,左移八次
  delay() ;
 }
 putchar('\n');
 ledbuf[i] = 0 ; //将数组清0,等待进入下一行
 }
}
//跑马灯从低位到高位流
void test_high_to_low_bit()
{
 int i , j ;
 int tick ;
 static int ledbuf[10] ;
 for(i = 0 ; i < 10 ; i++)
 {
 ledbuf[i] = 0x80 ; //设定从高位的第一个LED灯的位置
 for(j = 0 ; j < 8 ; j++)
 {
  printf("%p ",ledbuf[i]);
  ledbuf[i] >>= 1 ; //将数组的第一个元素右移一位,一共右移八位
  delay() ;
 }
 putchar('\n');
 ledbuf[i] = 0 ;//将数组清0,等待进入下一行</span>
 }
}
int main(void)
{
 test_low_to_high_bit() ;
 putchar('\n');
 test_high_to_low_bit() ;
 return 0 ;
}

运行结果:

运行结果很明显,第一个是从第一位移位到第八位,移动了8次,移动了十行。

第二个是反着来的。

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

这种问题的分析就要复杂很多啦,所以,一个流水灯,简单可以简单到不用两分钟你可以写出来,复杂可以复杂到可能你想一天都想不出来,所以,无论遇到什么问题,做一下总结,下次遇到问题的时候就可以熟能生巧。没有写不出的能实现程序,没有实现不了的软件需求。只有头脑简单的程序员。加油吧,各位!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • 嵌入式项目使用C语言结构体位段特性实现断言宏校验数据范围有效性的方法

    关于位段的特性这里就不多说了,多去看看相应的C语言书籍都会有介绍了. 今天来介绍断言宏.什么是断言宏?断言宏可以认为是校验数据范围的有效性的一个宏的实现.我们来看看代码: #include <stdio.h> //结构体位段 #define CHECK(x) sizeof(struct {unsigned:(-!!(x));}) //检查常量是否在一定范围之内,如果不在范围之内,则编译报错 //比如定义一个0到1000的范围,如果传入的xxx小于0或者大于1000,则编译器发现会报错 #def

  • 关于javascript获取内联样式与嵌入式样式的实例

    通过style属性设置背景图案 <!--html--> <div id="change"> change color </div> /*css*/ #change { border: 1px solid black; width: 200px; height: 200px; text-align: center; line-height: 200px; } //js change.style.backgroundColor="purple&

  • 嵌入式C语言查表法在项目中的应用

    嵌入式C实战项目开发技巧:对一个有规律的数组表进行位移操作的方法 就像下面的这个表 之前写过上面这个标题的一篇文章,讲的是以位移的方式去遍历表中的数据,效率非常高,但是,如果要实现一个乱序的流水灯或者跑马灯的话,思考一个这样的算法是不可取的,很费时间,也很费脑力,于是,今天就说一说查表法,如果在程序中运用查表法,不论多么复杂的程序,只要符合一张表,那都可以实现,非常简单,体力活而已,接下来看看下面这个程序,对上面这个进行操作吧. #include <stdio.h> #include <

  • javascript动态添加样式(行内式/嵌入式/外链式等规则)

    添加CSS的方式有行内式.嵌入式.外链式.导入式 a)动态引入样式表文件: 复制代码 代码如下: function loadLink(url){ var link = document.createElement("link"); link.type = "text/css"; link.rel = "stylesheet"; link.href = url; var head = document.getElmentsByTagName(&qu

  • JS实现PC手机端和嵌入式滑动拼图验证码三种效果

    PC和手机端网站滑动拼图验证码效果源码,同时包涵了弹出式Demo,使用ajax形式提交二次验证码所需的验证结果值,嵌入式Demo,使用表单形式提交二次验证所需的验证结果值,移动端手动实现弹出式Demo三种效果 首先要确认前端使用页面,比如登陆页面 <script src="http://code.jquery.com/jquery-1.12.3.min.js"></script> <script src="http://static.geetes

  • JavaScript基本的输出和嵌入式写法教程

    JavaScript 没有任何打印或者输出的函数. 在 HTML 中, JavaScript 通常用于操作 HTML 元素. 操作 HTML 元素 如需从 JavaScript 访问某个 HTML 元素,您可以使用 document.getElementById(id) 方法. 请使用 "id" 属性来标识 HTML 元素,并 innerHTML 来获取或插入元素内容: 实例 <!DOCTYPE html> <html> <body> <h1&

  • 嵌入式C实战项目开发技巧:对一个有规律的数组表进行位移操作的方法

    在嵌入式项目开发中,LED灯的操作是一定要会的,也是基础中的基础,比如用51单片机写个跑马灯,这不简单嘛,定义一个数组把那8个跑马灯存起来,然后搞个for循环不就可以了嘛,但是,实际工作开发中写一个跑马灯可不像学校和书本上那么简单噢,往往最简单的东西,有可能也是最复杂的.现在我的需求是这样的,我要求实现以下形式的流水灯: 跑马灯在这个表格中是一位一位进行存储的,如果要一行全亮,那么写0xff,灯就全亮了,写0x00,灯就全灭了. 要求从led1流水到led100这个灯,也就是实现100个灯的跑马

  • 30条android项目开发技巧与经验总结

    1.如果是阅读型文本(例如一篇文章),不需要固定大小的,textSize可以使用sp:如果是展示型文本(例如按钮中的文本),其大小受到限制的,textSize可以使用dp. 2.使用json用作网络数据传输时,应该使用String字段取代int字段. 3.按照现在正常密度比(系统的densityDPI根据分辨率和屏幕尺寸为正常的120.160.240.320.480.640时)9:16的安卓机其尺寸为(360dp*540dp).UI有时会根据iPhone机型使用750px*1334px作图,而按

  • javaweb实战之商城项目开发(二)

    上一篇<javaweb实战之商城项目开发(一)>已经把实体类,分页工具创建好了,这一篇利用mybatis创建DAO层. 另外mybatis的api文档可以参考 一.mybatis的使用 1. 引入架包 这里引入mybatis和mysql的架包到lib中 2. 编写Config.xml配置数据库环境 先贴代码,然后逐个解释 <?xml version="1.0" encoding="utf-8" ?> <!DOCTYPE configur

  • javaweb实战之商城项目开发(三)

    接着上一篇<javaweb实战之商城项目开发(二)>这一篇主要实现通用的BaseDao.java和使用resultMap映射关联对象 一.通用的BaseDao.java 既然要大家都能用,所以使用了泛型.其中要注意的问题就是类似User.getClass().getName()这样的代码是需要修改的.修改方法就是使用参数Class tc传递过来,然后在使用tc.getName()即可. 完整代码: package com.dao; import com.model.Pager; import

  • Vue3结合TypeScript项目开发实战记录

    目录 概述 1.compositon Api 1.ref 和 reactive的区别? 2.周期函数 3.store使用 4.router的使用 2.关注点分离 3.TypeScript支持 总结 概述 Vue3出来已经有一段时间了,在团队中,也进行了大量的业务实践,也有了一些自己的思考. 总的来说,Vue3无论是在底层的原理上,还是在业务的实际开发中,都有了长足的进步. 使用 proxy 代替之前的 Object.defineProperty 的API,性能更加优异,也解决了之前vue在处理对

  • node vue项目开发之前后端分离实战记录

    前言 本文主要介绍了关于node vue前后端分离的相关资料,分享出来供大家参考学习,下面随着小编来一起学习学习吧. node vue项目开发 最近看了近一周的vue开发,有诸多感触,我之前接触过react.angular所以特别想学学久仰大名的vue.学习半天以后发现,接触到的东西多了,学习起来就是容易很多,vue的指令我能个联想到angular的指令,vue组件化设计类似于react的组件化设计,包括一些router的设置跟react里的路由或者nodejs里的路由都差不多,vuex更是根据

  • 从零开始搭建一个react项目开发

    本文介绍了从零开始搭建一个react项目开发,分享给大家,具体如下: 1.npm init 生成 package.json 文件. 2.安装各种需要的依赖: npm install  --save react - 安装React. npm install  --save react-dom 安装React Dom,这个包是用来处理virtual DOM.这里提一下用React Native的话,这里就是安装react-native. npm install  --save-dev webpack

  • vue多页面项目开发实战指南

    目录 单页应用和多页应用 单页应用 多页应用 优缺点 配置多页应用 1. 修改vue.config.js 2. 修改title 3. 合并第三方库 4. 打包第三方scss 5. 其它常见设置 总结 单页应用和多页应用 单页应用 SPA(single page application): 单页面应用,即一个web项目就只有一个页面(即一个HTML文件). 就是把整个项目的所有页面的所有内容分成了很多的小块(就是组件),可以重复利用的,可以任意调整的组件,每个组件就是一个独立的部分(包括html,

  • JavaWeb购物车项目开发实战指南

    目录 一.项目前提 二.数据库的创建 三.eclipse进行创建包和类: 四.主要实现功能 1.购物车用户登录 2.商品显示 3.购物车添加&商品总数和价格的计算 总结 一.项目前提 1.购物车并不是一直放数据库 2.选择使用的技术: session:(购物车项目使用session) 好处:快(放在内存当中),存对象的坏处:占用内存,服务器意外待机数据会丢失 cookie 好处:不占用内存,存储很久坏处:存在客户端上,只能存String,数据有泄露的风险 二.数据库的创建 用户表 create

随机推荐