<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 單片機(jī)位操作的邏輯運(yùn)算詳解

          單片機(jī)位操作的邏輯運(yùn)算詳解

          作者: 時(shí)間:2016-11-30 來源:網(wǎng)絡(luò) 收藏
          不僅這個(gè),我還可以分別對(duì)兩個(gè)不同的位進(jìn)行操作。所以我可以這樣:
          uchar a=1;
          a |= (1<<2)|(1<<3)|(1<<4)|(1<<5);
          這樣的話,就可以把第3、4、5、6位全部置1,而且保持a的第1位不變,這個(gè)公式的最終結(jié)果是00111101b。 同樣,這招,在全部置位也有效。但是a原來的值就消失了
          uchar a=1;
          a = (1<<2)|(1<<3)|(1<<4)|(1<<5);
          那么結(jié)果只有4個(gè)1,00111100b,第1位的一就沒有了
          同樣比如(3<<1)也可以出現(xiàn)在單一置位當(dāng)中
          uchar a=1
          a |= (3<<1);
          這個(gè)表達(dá)式結(jié)果為00000111b。到這,置位操作,基本上就都在這了,大多數(shù)程序,這幾個(gè)方法也夠了,這也是晚上普遍的方法,也許還有其他的方法,如果你知道,希望能夠通知我。下面說說清0,清0可以用(&=~),舉個(gè)例子:
          uchar a=0xfe;
          a &=~ (1<<4);
          讓我們來分析一下這個(gè)式子,首先這和上面一樣,是一個(gè)含有復(fù)合的賦值運(yùn)算符的表達(dá)式。拆開來以后
          a=a&(~(1<<4))
          這個(gè)式子比剛才要復(fù)雜一些,讓我們先來看看括號(hào)最里面的(1<<4)
          結(jié)果為10000b,然后我們把這個(gè)式子取反,因?yàn)閍是8位的,所以結(jié)果被轉(zhuǎn)換成11101111b,然后我們?cè)诎補(bǔ)和這個(gè)結(jié)果進(jìn)行與運(yùn)算。因?yàn)榕c運(yùn)算的規(guī)律是全1為1。
          a 11111110b
          與操作 11101111b
          結(jié)果 11101110b
          現(xiàn)在,我們清楚了這個(gè)結(jié)果時(shí)怎么來的了。
          同樣同時(shí)使兩位變?yōu)?也可以通過(3<<5)來實(shí)現(xiàn),比如
          uchar a=0xfe;
          a &=~ (3<<4);
          這樣也是可以得到希望的結(jié)果的,但是需要注意一下,(1<<2)|(1<<3)|(1<<4)|(1<<5),像這種一位一位的變則需要注意一下了。因?yàn)榍辶阒邢刃枰》?,所以如果希望一位一位的變,則需要用括號(hào),把結(jié)果擴(kuò)起來,形成一個(gè)值,然后再取反,才能得到想要的結(jié)果了。比如
          uchar a=0xfe;
          /*
          注意,這樣做是不對(duì)的,結(jié)果只會(huì)把第二位清0,
          a &=~ (1<<2)|(1<<3)|(1<<4)|(1<<5);
          */
          a &=~ ((1<<2)|(1<<3)|(1<<4)|(1<<5));
          這樣做才能達(dá)到希望的效果。
          可能大家會(huì)想,用(&=)會(huì)得到啥樣的結(jié)果呢?這我試了一下
          uchar a=0xfe
          a &= (1<<4);
          首先(1<<4),結(jié)果是10000,然后再進(jìn)行與操作
          a 11111110b
          與操作 00010000b
          結(jié)果 00010000b
          這個(gè)結(jié)果不是我們想要的,不過這個(gè)結(jié)果可以達(dá)到屏蔽我們不要的位,比如在判斷中,判斷最高位是否為1,可以采用這樣的語句
          if(a&0x80)
          這句話,如果a的最高位為1,則為真,如果最高位不為1,則為假,如果位最高位為1的話,結(jié)果為10000000,在c語言中不為0,則為真,所以判定某位是否為1時(shí),可以采用&操作。
          以上就是簡(jiǎn)單的總結(jié)了一下置位,清零的邏輯操作的方法。
          上一頁 1 2 下一頁

          評(píng)論


          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();