OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 1965|回复: 4

关于程序运行效率的问题

[复制链接]

233

主题

961

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1814
金钱
1814
注册时间
2011-10-9
在线时间
230 小时
发表于 2017-10-18 10:07:11 | 显示全部楼层 |阅读模式
1金钱
以下代码(手打示意,请忽略其中 数据有无声明、定义,有无主循环之类的东西) 运行一次 要 150us  是否太久了 时间还能缩短吗?

定义全局数组  
u16 a1[15];
u16 a2[15];.......................一直定义到a22


main
{
u8 i;
   init_a(); //初始化内存数组

   //从这里开始计时
  for (i=1;i<15;i++)
                 {
                         
                         switch (add)
                         {
                                 case 1:
                                           ad=a1[i];
                                           break;
                                 case 2:
                                              ad=a2[i];
                                       break;
                                 case 3:
                                              ad=a3[i];
                                                                break;
                                 case 4:
                                              ad=a4[i];
                                                                break;
                                 case 5:
                                              ad=a5[i];
                                                                break;
                                 case 6:
                                              ad=a6[i];
                                                                break;
                                 case 7:
                                              ad=a7[i];
                                                                break;
                                 case 8:
                                              ad=a8[i];
                                                                break;
                                 case 9:
                                              ad=a9[i];
                                                                break;
                                 case 10:
                                              ad=a10[i];
                                                                break;
                                 case 11:
                                              ad=a11[i];
                                                                break;
                                 case 12:
                                              ad=a12[i];
                                                                break;
                                 case 13:
                                              ad=a13[i];
                                                                break;
                                 case 14:
                                              ad=a14[i];
                                                                break;
                                 case 15:
                                              ad=a15[i];
                                                                break;
                                 case 16:
                                              ad=a16[i];
                                                                break;
                                 case 17:
                                              ad=a17[i];
                                                                break;
                                 case 18:
                                              ad=a18[i];
                                                                break;
                                 case 19:
                                              ad=a19[i];
                                                                break;
                                 case 20:
                                              ad=a20[i];
                                                                break;
                                 case 21:
                                              ad=a21[i];
                                                                break;
                                 case 22:
                                              ad=a22[i];
                                                                break;
                         
                         
                         }
               
               
                 
                 }
//这里计时结束   合计运行一次  要150us



}


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

349

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1046
金钱
1046
注册时间
2017-5-19
在线时间
335 小时
发表于 2017-10-18 11:13:19 | 显示全部楼层
u16 a[22][15];


main
{
u8 i;
   init_a(); //初始化内存数组

   //从这里开始计时
  for (i=1;i<15;i++)
  {
         ad=a[add-1][i];
   }
我瞎想的,你这个很有规律,这样不行么?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-10-19 01:09:51 | 显示全部楼层
你怎么统计的?、
回复

使用道具 举报

233

主题

961

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1814
金钱
1814
注册时间
2011-10-9
在线时间
230 小时
 楼主| 发表于 2017-10-20 16:14:09 | 显示全部楼层
找个IO  然后  代码前 IO=0  代码后 IO=1  用示波器测这个  IO的时间
回复

使用道具 举报

2

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
76
金钱
76
注册时间
2017-9-28
在线时间
19 小时
发表于 2017-10-25 11:51:43 | 显示全部楼层
1.不要采用轮询的思想,根据用一个字节的一位,的代表一个ADD,根据ADD直接调用需要的case,不需要的case不调用执行,即可减少没必要的执行时间,这个也是操作系统中的思想。
2.提高系统主频,从而提高运算和执行效率。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-8 19:25

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表