久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 6054|回復(fù): 30
打印 上一主題 下一主題
收起左側(cè)

單片機(jī)流水燈,只循環(huán)一次,有老哥幫看看嗎

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:624696 發(fā)表于 2019-11-15 17:05 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
這是一個(gè)流水燈,先從兩側(cè)向中間亮,在從中間向兩側(cè)亮,為什莫只循環(huán)一次呢

有沒(méi)有老哥給說(shuō)下啊

先謝謝了

單片機(jī)源程序如下:
  1. #include <reg52.h>

  2. unsigned char code table[] = {
  3. 0xff,0x7e,0x3c,0x18,0x00,                //從兩側(cè)向中間點(diǎn)亮
  4. 0xff,0xe7,0xc3,0x81,0x00                //從中間向兩側(cè)點(diǎn)亮



  5. };
  6. unsigned char i;
  7. void delay()
  8. {
  9.          unsigned int s;
  10.         for (s=0;s<30000;s++);
  11.         
  12. }
  13. void main ()
  14. {
  15.         while(1)
  16.         {
  17.                 if (table[i]!= 0xee)
  18.                 {
  19.                         P1 = table[i];
  20.                         i++;
  21.                         delay();
  22.                 }
  23.                 else
  24.                 {
  25.                         i=0;
  26.                         
  27.                
  28.                 }
  29.         
  30.         }
  31.         
  32.         
  33. }
復(fù)制代碼
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:394424 發(fā)表于 2019-11-16 08:47 | 只看該作者
看門(mén)狗是不是復(fù)位了
回復(fù)

使用道具 舉報(bào)

板凳
ID:25310 發(fā)表于 2019-11-16 08:52 | 只看該作者
if (table[i]!= 0xee)  下一個(gè)條件 這里如果相等了要讓他等于0吧
回復(fù)

使用道具 舉報(bào)

地板
ID:213173 發(fā)表于 2019-11-16 10:38 | 只看該作者
if(table[i]!= 0xee)的條件永遠(yuǎn)滿(mǎn)足,i++;跑飛。
回復(fù)

使用道具 舉報(bào)

5#
ID:275826 發(fā)表于 2019-11-16 11:01 | 只看該作者
table[]里沒(méi)有OXEE,i一直加,上天了
回復(fù)

使用道具 舉報(bào)

6#
ID:511501 發(fā)表于 2019-11-16 11:57 來(lái)自手機(jī) | 只看該作者
table[i]永遠(yuǎn)不會(huì)等于0xee,所以跑一遍就超出數(shù)組大小了,可以這樣改:主函數(shù)while(1)里面全部替換成:
回復(fù)

使用道具 舉報(bào)

7#
ID:511501 發(fā)表于 2019-11-16 12:00 來(lái)自手機(jī) | 只看該作者
for(i=0;i<10;i++){P1=table[i];delay();}
回復(fù)

使用道具 舉報(bào)

8#
ID:643100 發(fā)表于 2019-11-16 12:51 | 只看該作者
跑完一次后,就會(huì)一直循環(huán)i++這個(gè)地方,跑飛了
回復(fù)

使用道具 舉報(bào)

9#
ID:272485 發(fā)表于 2019-11-16 13:44 | 只看該作者
i賦初值為0,數(shù)組里面結(jié)尾加個(gè)0xee也行
回復(fù)

使用道具 舉報(bào)

10#
ID:624696 發(fā)表于 2019-11-16 15:43 | 只看該作者
huh 發(fā)表于 2019-11-16 13:44
i賦初值為0,數(shù)組里面結(jié)尾加個(gè)0xee也行

謝謝了,;老哥,你這個(gè)方法是可以的
回復(fù)

使用道具 舉報(bào)

11#
ID:624696 發(fā)表于 2019-11-16 15:45 | 只看該作者
wulin 發(fā)表于 2019-11-16 10:38
if(table!= 0xee)的條件永遠(yuǎn)滿(mǎn)足,i++;跑飛。

是的,對(duì)的,東 了謝謝老哥
回復(fù)

使用道具 舉報(bào)

12#
ID:624696 發(fā)表于 2019-11-16 15:45 | 只看該作者
tyrl800 發(fā)表于 2019-11-16 11:01
table[]里沒(méi)有OXEE,i一直加,上天了

謝謝了,沒(méi)錯(cuò),我加了0xee就可以了
回復(fù)

使用道具 舉報(bào)

13#
ID:624696 發(fā)表于 2019-11-16 15:46 | 只看該作者
1842058863 發(fā)表于 2019-11-16 12:51
跑完一次后,就會(huì)一直循環(huán)i++這個(gè)地方,跑飛了

明白了,謝謝老哥
回復(fù)

使用道具 舉報(bào)

14#
ID:624696 發(fā)表于 2019-11-16 15:46 | 只看該作者
huh 發(fā)表于 2019-11-16 13:44
i賦初值為0,數(shù)組里面結(jié)尾加個(gè)0xee也行

謝謝老哥,加了0xee確實(shí)可以了
回復(fù)

使用道具 舉報(bào)

15#
ID:624696 發(fā)表于 2019-11-16 15:50 | 只看該作者

謝謝謝謝,這樣也是可以的,厲害哦大家
回復(fù)

使用道具 舉報(bào)

16#
ID:624696 發(fā)表于 2019-11-16 15:53 | 只看該作者
Wprogrammer 發(fā)表于 2019-11-16 08:47
看門(mén)狗是不是復(fù)位了

不太懂你的意思,還是謝謝了
回復(fù)

使用道具 舉報(bào)

17#
ID:603411 發(fā)表于 2019-11-16 17:20 | 只看該作者
數(shù)組中沒(méi)有oxee這個(gè)值,也就是i不停地加,一直執(zhí)行if (table[i]!= 0xee)中的內(nèi)容,所以就只循環(huán)一次
回復(fù)

使用道具 舉報(bào)

18#
ID:263427 發(fā)表于 2019-11-16 19:00 | 只看該作者
看到樓上已經(jīng)解決的差不多了,但是原理還不太清楚,在這兒我著重闡述一下原理。

if語(yǔ)句里面沒(méi)有結(jié)束條件,所以永遠(yuǎn)不可能出if,更不可能去執(zhí)行while語(yǔ)句,究其原因,是i++沒(méi)有結(jié)束條件,解決的方法樓上已經(jīng)給出,加一個(gè)限制條件就好了。
回復(fù)

使用道具 舉報(bào)

19#
ID:245004 發(fā)表于 2019-11-16 20:21 | 只看該作者
  1. #include <reg52.h>

  2. #define TAB_LENGTH 10
  3. unsigned char code table[TAB_LENGTH] = {
  4.     0xff, 0x7e, 0x3c, 0x18, 0x00,  //從兩側(cè)向中間點(diǎn)亮
  5.     0xff, 0xe7, 0xc3, 0x81, 0x00}; //從中間向兩側(cè)點(diǎn)亮
  6. void delay(void) {
  7.   unsigned int s;
  8.   for (s = 0; s < 30000; s++) {
  9.   }
  10. }
  11. void main(void) {
  12.   while (1) {
  13.     unsigned char i;

  14.     for (i = 0; i < TAB_LENGTH; i++) {
  15.       P1 = table[i];
  16.       delay();
  17.     }
  18.   }
  19. }
復(fù)制代碼
這樣寫(xiě)試試。

回復(fù)

使用道具 舉報(bào)

20#
ID:245004 發(fā)表于 2019-11-16 20:28 | 只看該作者
如果一定要用if語(yǔ)句,那就把主函數(shù)這樣寫(xiě):
  1. void main(void) {
  2.   while (1) {
  3.     unsigned char i;

  4.     if (i < TAB_LENGTH) {
  5.       P1 = table[i];
  6.       delay();
  7.       i++;
  8.     } else {
  9.       i = 0;
  10.     }
  11.   }
  12. }
復(fù)制代碼



回復(fù)

使用道具 舉報(bào)

21#
ID:643346 發(fā)表于 2019-11-16 20:37 | 只看該作者
這個(gè)是不是忘加while循環(huán)里了,還有要加個(gè)掃描
回復(fù)

使用道具 舉報(bào)

22#
ID:93224 發(fā)表于 2019-11-17 15:48 | 只看該作者
數(shù)組里面沒(méi)有0xee
回復(fù)

使用道具 舉報(bào)

23#
ID:296956 發(fā)表于 2019-11-17 17:10 | 只看該作者
table[] 數(shù)組后面加個(gè)0xee 的值。
回復(fù)

使用道具 舉報(bào)

24#
ID:624696 發(fā)表于 2019-11-26 22:05 | 只看該作者
13144088433 發(fā)表于 2019-11-16 11:57
table永遠(yuǎn)不會(huì)等于0xee,所以跑一遍就超出數(shù)組大小了,可以這樣改:主函數(shù)while(1)里面全部替換成:

為什莫led燈點(diǎn)亮不是按照數(shù)組的順序進(jìn)行的呢???
回復(fù)

使用道具 舉報(bào)

25#
ID:624696 發(fā)表于 2019-11-26 22:07 | 只看該作者
huh 發(fā)表于 2019-11-16 13:44
i賦初值為0,數(shù)組里面結(jié)尾加個(gè)0xee也行

為什么led燈的點(diǎn)亮順序不是按照數(shù)組里的順序來(lái)的呢??為什么不是一個(gè)一個(gè)點(diǎn)亮呢,而是同時(shí)點(diǎn)亮
回復(fù)

使用道具 舉報(bào)

26#
ID:213173 發(fā)表于 2019-11-27 09:56 | 只看該作者
TRX007 發(fā)表于 2019-11-26 22:07
為什么led燈的點(diǎn)亮順序不是按照數(shù)組里的順序來(lái)的呢??為什么不是一個(gè)一個(gè)點(diǎn)亮呢,而是同時(shí)點(diǎn)亮

按你的題意,先從兩側(cè)向中間亮,在從中間向兩側(cè)亮,反復(fù)循環(huán)。
  1. #include <reg52.h>

  2. unsigned char code table[] = {0x7e,0xbd,0xdb,0xe7};
  3. unsigned char i;
  4. void delay()
  5. {
  6.         unsigned int s;
  7.         for(s=0;s<30000;s++);        
  8. }
  9. void main ()
  10. {
  11.         while(1)
  12.         {
  13.                 for(i=0;i<4;i++)
  14.                 {
  15.                         P1=table[i];
  16.                         delay();
  17.                 }
  18.                 for(i=2;i>0;i--)
  19.                 {
  20.                         P1=table[i];
  21.                         delay();
  22.                 }
  23.         }       
  24. }
復(fù)制代碼
回復(fù)

使用道具 舉報(bào)

27#
ID:624696 發(fā)表于 2019-11-27 10:19 | 只看該作者
wulin 發(fā)表于 2019-11-16 10:38
if(table!= 0xee)的條件永遠(yuǎn)滿(mǎn)足,i++;跑飛。

老哥, 請(qǐng)問(wèn)為什么led的點(diǎn)亮順序是同時(shí)點(diǎn)亮呢,而不是按數(shù)組的順序一個(gè)一個(gè)點(diǎn)亮呢?
回復(fù)

使用道具 舉報(bào)

28#
ID:624696 發(fā)表于 2019-11-27 10:20 | 只看該作者
bh2030693 發(fā)表于 2019-11-16 20:28
如果一定要用if語(yǔ)句,那就把主函數(shù)這樣寫(xiě):

請(qǐng)問(wèn),為什么led點(diǎn)亮不是按照數(shù)組的順序一個(gè)個(gè)點(diǎn)亮,而是同時(shí)亮呢?
回復(fù)

使用道具 舉報(bào)

29#
ID:213173 發(fā)表于 2019-11-27 10:49 | 只看該作者
TRX007 發(fā)表于 2019-11-27 10:19
老哥, 請(qǐng)問(wèn)為什么led的點(diǎn)亮順序是同時(shí)點(diǎn)亮呢,而不是按數(shù)組的順序一個(gè)一個(gè)點(diǎn)亮呢?

按你的題意,先從兩側(cè)向中間亮,再?gòu)闹虚g向兩側(cè)亮,反復(fù)循環(huán)。看26樓回復(fù)。
回復(fù)

使用道具 舉報(bào)

30#
ID:415088 發(fā)表于 2019-11-30 10:23 | 只看該作者
if (table[i]!= 0xee) 這里的判斷條件有問(wèn)題
回復(fù)

使用道具 舉報(bào)

31#
ID:653047 發(fā)表于 2019-11-30 20:16 | 只看該作者
很顯然在數(shù)組table中,沒(méi)有數(shù)能讓table[i]==0xee,也就是說(shuō),while循環(huán)只是在table[i]!=0xee的條件下循環(huán),i的值只會(huì)無(wú)限增大,不歸零
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲综合区 | 国产亚韩| 在线观看免费黄色片 | 欧美成人影院在线 | 精品一二区| av中文字幕在线播放 | 国产欧美在线播放 | 欧美8一10sex性hd | 国产精品一区二区三区久久久 | 国产一区二区三区久久久久久久久 | 免费视频久久 | 国产成人精品一区二区三区网站观看 | 99热精品6| 国产高清无av久久 | 亚洲精品视频久久 | 九九视频在线观看视频6 | 日韩不卡一区二区 | av网站在线看 | 99成人| 免费xxxx大片国产在线 | 精品综合 | 精品国产免费一区二区三区演员表 | 91精品国产综合久久精品 | 97影院在线午夜 | 亚洲精品久久久久久一区二区 | 成人av一区 | 国产99在线 | 欧美 | 亚洲第一天堂 | 亚洲一区 中文字幕 | 日韩久久久久久久久久久 | 尤物视频在线免费观看 | 国产传媒毛片精品视频第一次 | 国产免费一级一级 | 精品国产乱码久久久久久中文 | 久久久久欧美 | 久久精品日产第一区二区三区 | 久久国产成人 | 日本中文在线 | 国产美女精品 | 91精品国产一区二区三区 | 欧美精品久久久久 |