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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3868|回復: 1
收起左側

怎樣判斷一個變量是否有連續性

[復制鏈接]
ID:183246 發表于 2017-4-7 15:15 | 顯示全部樓層 |閱讀模式
有沒有好的方法(C語言)判斷:一個16bit變量里面是否有連續8個以上的1?
如0xFF00就有,0xFEFE就沒有, 0x7F80就有,等等。
方法有,比如我想到的是用窗口法:先和0xFF00比較,然后和0x7F80比較.....最后和0xFF比較。 但這個方法太蠢了。
16bit數據其實是輸入碼流,你不能隨便改變它的值,因為它隨時(2kHz速率)被中斷更改。我想到的方式是:
disableInt();
data=buf;
buf=0;
enableInt();
這樣就用data把buf里面的數據取出。但后期處理更復雜。因為要做數據拼接。我不知道怎么做拼接數據,因為第二次的數據要哪一段拼接到第一次數據我還沒有想清楚。拼接好了后再判斷,就像T叔說的那樣沒有問題了。
所以,對這樣的碼流信號,有什么好辦法判斷8個連1信號(幀頭)?

當然可以在中斷服務程序里面1bit1bit地處理,這樣邏輯比較簡單。

但如果在中斷處理bit數據,帶來的問題是所有的收數據處理都必須在中斷中處理,這樣中斷函數太大了,不合理。
所以還是回到初始,在主程序中處理input data。這樣中斷函數必須記錄接收到的數據序列和bit個數。
回到主程序中,問題又來了:bit個數不一定是16位,而是一個變化數字。要考慮的事情有:
1.    等待與下一批數據拼接.
2.   檢查bit個數是否大于7,如果沒有,則跳到5;(其實處理也可以,比如記錄現有的1bit,但太復雜了)
3.   查數列中有沒有連續8個1,檢測的辦法總是有的;
4.   如果檢測到了,則到7
5.   找到最后一個0bit,保留右邊的全部1bit,左邊的數據全部丟棄,更新有效bit個數
6.   回到1;
7.   到下一個狀態

回復

使用道具 舉報

ID:187614 發表于 2017-4-9 09:53 | 顯示全部樓層
很簡單:可采用定值比較法,僅僅8個值而已!
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日本欧美国产在线观看 | 免费毛片网 | 亚洲一区| 欧美成人激情视频 | 亚洲色片网站 | 亚洲一区二区三区免费视频 | 天久久| 欧美一级片黄色 | 狠狠爱网址 | 亚洲a在线观看 | 国产一级网站 | 97国产一区二区精品久久呦 | 91热在线| 天天干天天操天天射 | 日韩在线国产精品 | 91在线色视频 | 成人国产在线视频 | 国产一级免费在线观看 | 国产婷婷综合 | 天天拍天天操 | 91视频国产精品 | 91精品久久久久久久久久 | 一区在线视频 | 亚洲精品91 | 一级h片| 一区二区三区视频在线免费观看 | 日本一区二区高清不卡 | 日韩1区 | 亚洲国产视频一区 | 国产一区不卡 | 日日操夜夜操天天操 | 狠狠干狠狠插 | 国产一区 | 国产精品日韩欧美一区二区三区 | 久久99精品久久久久婷婷 | 一区二区三区亚洲精品国 | 欧美久久久久久久久中文字幕 | 射欧美| 99re在线视频 | 6080yy精品一区二区三区 | 成av在线 |