欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

單片機寄存器賦的值是怎么來的?

5RJg_mcuworld ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2017-10-23 15:57 ? 次閱讀
這篇文章適合剛剛?cè)腴T的單片機小白看。

單片機在電學(xué)里面,屬于很簡單的一種器件,外表看,就是一個芯片,長著很多的腳。內(nèi)部,就是一堆寄存器。不同的單片機,外部表現(xiàn)就是形狀和引腳數(shù)量和引腳名稱可能不一樣,內(nèi)部,就是寄存器名稱不一樣。

我們要做的,就是寫程序控制單片機里面的寄存器,然后通過引腳表現(xiàn)出來完成各種電子產(chǎn)品。

所以,你在看別人寫的程序的時候,會經(jīng)常看到給單片機寄存器賦值的語句。下面就以最簡單的控制51單片機引腳高低電平來說明一下。(不要總是存在51單片機已經(jīng)淘汰的想法,51單片機至今任然是出貨量最大的單片機,并且各大公司每年都有新款的51單片機推出,功能越來越強勁,做產(chǎn)品,要選最合適的單片機,而不要總想用牛逼的單片機。)

例如,單片機P1口有8個引腳,分別為P1.0~P1.7,如果想讓P1口的8個引腳都輸出高電平,是這么寫:P1=0XFF;如果想讓P1口的8個引腳都輸出低電平,是這么寫:P1=0X00;如果只讓P1.0輸出高電平,其他引腳輸出低電平,是這么寫:P1=0X01......

這些值是怎么來的呢?

計算方法:

一個數(shù),前面以0X開頭,標(biāo)示后面的數(shù)是十六進制數(shù)。所以首先,我們先要知道十進制和十六進制的轉(zhuǎn)換。

十六進制:0 1 2 3 4 5 6 7 8 9 A B C D E F

十進制: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

以上十六進制和十進制是對應(yīng)關(guān)系,例如B對應(yīng)11。

單片機和計算機一樣,是以“位”為最小單片機,例如,P1是一個8位的寄存器。P1寄存器的8個位名稱分別是:P1.7 P1.6 P1.5 P1.4 P1.3 P1.2 P1.1 P1.0

上面的0X開頭的數(shù),是以4個“位”為一個單位進行計算,以8421碼進行相加計算,聽這里很迷糊吧。舉個例子就明白了。

你可以做一個這樣的表格:

從上表看出,把寄存器的“位”,從高到低排列,然后以4個為一組,對應(yīng)的8421碼如上圖所示。

給寄存器寫值,實際上就是給它的每個位寫0或者1,例如要使得哪個引腳為高電平,就給對應(yīng)的位寫1;要使得哪一個引腳為低電平,就給對應(yīng)的位寫0。然后把對應(yīng)為1的8421加起來,以4個位為一組。

例如,我們要讓每一個引腳都輸出高電平,就是每個位的值都為1,那對應(yīng)寄存器的高四位,8+4+2+1=15,15對應(yīng)的是十六進制的F,再看寄存器的低四位,8+4+2+1=15,還是對應(yīng)F,所以最后的值就是0xFF。

再看,如果讓每一個引腳都輸出低電平,就是每個位的值都是1,前面說過,只有對應(yīng)位是1,才把它們的8421加起來,現(xiàn)在都是0,所以都不用加,結(jié)果就是0x00。

再看,如果只讓P1.0引腳是高電平,其他引腳輸出低電平,那么,只有P1.0對應(yīng)的位是1,其它的位是0,所以,只需要取P1.0上面的1碼,所以結(jié)果就是0x01。

再看,如果讓P1.0、P1.1、P1.7、P1.5輸出高電平,其它引腳輸出低電平,那么對應(yīng)的值如下圖所示:

我們看寄存器的高四位,取對應(yīng)1上面的碼8+2=10,10對應(yīng)十六進制的A,再看寄存器的低四位,取對應(yīng)1上面的碼2+1=3,3對應(yīng)的十六進制還是3,所以結(jié)果就是0XA3,這是,你寫P1=0XA3,就可以使得引腳該高的高,該低的低了。

不管是51的8位寄存器,還是ARM的32位寄存器,寄存器中的每一個位都有一定的用意,這些用意可以查看單片機的用戶手冊得知,你只需要按照你的要求,給對應(yīng)的位寫1或者0,然后利用上面的方法得出結(jié)果,就可以操作單片機的寄存器了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6044

    文章

    44631

    瀏覽量

    639079
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5372

    瀏覽量

    121322

原文標(biāo)題:給單片機寄存器賦的值是怎么計算來的?

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機的SPI控制ADS1191,發(fā)送命令寫寄存器后讀取相應(yīng)寄存器就不一樣,而且每次讀出來的都不一樣,為什么?

    現(xiàn)用單片機的SPI控制ADS1191,使用內(nèi)置晶振時鐘,發(fā)送命令寫寄存器后,再讀取相應(yīng)寄存器就不一樣,而且每次讀出來的都不一樣,設(shè)置讓CLK腳在起振后輸出時鐘信號,示波器也測不到
    發(fā)表于 01-23 08:38

    用51單片機實現(xiàn)與LDC1000的通訊,讀取proximity data兩個寄存器里面的都是0x00,為什么?

    大家的幫助。 另外說一下,我們沒有改其他寄存器的初始,因為我們現(xiàn)在只想能讀出proximity data 里面的數(shù),精不精確還不重要。另外芯片所需要的TBCLK時鐘頻率是用51單片機定時
    發(fā)表于 01-13 07:41

    將LDC1000配置了0X0B寄存器,各寄存器都變成了相應(yīng)寄存器的Deffault,為什么?

    我將LDC1000各寄存器配置后,當(dāng)不配置0X0B,即傳感處于待機狀態(tài)時,單片機讀回來各寄存器是正常的,但當(dāng)配置了0X0B
    發(fā)表于 01-02 07:41

    用LDC1000EVM接單片機,單片機PWM輸出6MHZ的方波給LDCLK,為什么寄存器讀不到數(shù)據(jù)?

    你們好,我用LDC1000EVM的芯片和線圈那部分接飛思卡爾的單片機單片機PWM輸出6MHZ的方波給LDCLK,SPI給的SCK是4M及100K都嘗試過,寫寄存器SDI線上可以量到正確的波形
    發(fā)表于 12-11 07:59

    Modbus協(xié)議的讀取保持寄存器

    功能碼用于讀取從設(shè)備保持寄存器的內(nèi)容,不支持廣播模式。消息頓中指定了需要讀取的保持寄存器的起始地址和數(shù)目。而保持寄存器中各地址的具體內(nèi)容和意義則由設(shè)備開發(fā)者自行規(guī)定。
    的頭像 發(fā)表于 10-30 10:54 ?1933次閱讀

    單片機按鍵中斷配置教程

    一些小伙伴覺得單片機入門太難了,又要懂原理圖、又要懂寄存器、還要學(xué)編程語言。
    的頭像 發(fā)表于 10-23 16:30 ?784次閱讀
    <b class='flag-5'>單片機</b>按鍵中斷配置教程

    詳解寄存器模型鏡像

    DUT的配置寄存器是實際,reg_model有鏡像、期望的概念。
    的頭像 發(fā)表于 10-23 09:43 ?409次閱讀
    詳解<b class='flag-5'>寄存器</b>模型鏡像<b class='flag-5'>值</b>

    單片機io口怎么配置成輸出口

    單片機IO口配置成輸出口的過程通常涉及對單片機內(nèi)部寄存器的操作。不同型號的單片機寄存器配置和編程方式上可能有所不同,但基本原理是相似的。以下是一個通用的步驟,用于將
    的頭像 發(fā)表于 09-14 14:33 ?1005次閱讀

    寄存器是什么意思?寄存器是如何構(gòu)成的?

    在計算機科學(xué)中,寄存器(Register)是一個高速存儲單元,它位于中央處理(CPU)內(nèi)部,用于存儲計算機程序執(zhí)行過程中所需要的數(shù)據(jù)、指令地址或狀態(tài)信息。寄存器是計算機體系結(jié)構(gòu)中至關(guān)重要的組成部分,對計算機的運算速度和性能有著
    的頭像 發(fā)表于 08-02 18:23 ?4969次閱讀
    <b class='flag-5'>寄存器</b>是什么意思?<b class='flag-5'>寄存器</b>是如何構(gòu)成的?

    寄存器尋址的實現(xiàn)方式

    在計算機體系結(jié)構(gòu)中,寄存器尋址是一種常見的尋址方式,它允許程序直接訪問CPU內(nèi)部的寄存器。寄存器尋址可以提高程序的執(zhí)行效率,因為它避免了對內(nèi)存的訪問。 寄存器尋址的基本概念
    的頭像 發(fā)表于 07-12 10:36 ?882次閱讀

    寄存器分為基本寄存器和什么兩種

    寄存器是計算機中用于存儲數(shù)據(jù)的高速存儲單元,它們是CPU內(nèi)部的重要組成部分。寄存器可以分為基本寄存器和擴展寄存器兩種類型。 一、基本寄存器
    的頭像 發(fā)表于 07-12 10:31 ?1637次閱讀

    移位寄存器右移是怎么移位的

    移位寄存器是一種在數(shù)字電路和計算機科學(xué)中廣泛使用的存儲設(shè)備,它可以用來存儲和傳輸數(shù)據(jù)。在移位寄存器中,數(shù)據(jù)可以通過移位操作實現(xiàn)數(shù)據(jù)的傳輸和處理。移位寄存器的移位操作有兩種基本形式:左
    的頭像 發(fā)表于 07-12 10:14 ?1794次閱讀

    寄存器單片機的關(guān)系與區(qū)別

    在計算機系統(tǒng)中,寄存器單片機是兩個至關(guān)重要的概念。寄存器作為中央處理(CPU)內(nèi)部的重要組成部分,用于暫時存儲數(shù)據(jù)和指令,確保CPU能夠高效地進行數(shù)據(jù)處理和運算。而
    的頭像 發(fā)表于 05-30 17:17 ?933次閱讀

    ?51單片機串口通信詳細介紹-小白必看

    51單片機串口通信是單片機與外部設(shè)備通信的重要方式,它基于串行通信的原理,以字節(jié)為單位進行數(shù)據(jù)傳輸。在51單片機中,串口通信主要依賴于兩個關(guān)鍵寄存器:SBUF
    的頭像 發(fā)表于 04-17 09:33 ?2182次閱讀
    ?51<b class='flag-5'>單片機</b>串口通信詳細介紹-小白必看

    loop指令執(zhí)行時,隱含的寄存器

    當(dāng)執(zhí)行l(wèi)oop指令時,隱含的寄存器是CX寄存器。CX寄存器是循環(huán)計數(shù)寄存器,它存儲了循環(huán)的迭代次數(shù)。 在匯編語言中,loop指令用于實現(xiàn)循
    的頭像 發(fā)表于 02-14 16:15 ?1053次閱讀