在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

單片機(jī)是如何工作的?

STM32嵌入式開發(fā) ? 來源:STM32嵌入式開發(fā) ? 2023-05-08 09:55 ? 次閱讀

單片機(jī)內(nèi)部結(jié)構(gòu)分析

我們來思考一個問題,當(dāng)我們在編程器中把一條指令寫進(jìn)單片機(jī)內(nèi)部,然后取下單片機(jī),單片機(jī)就可以執(zhí)行這條指令,那么這條指令一定保存在單片機(jī)的某個地方,并且這個地方在單片機(jī)掉電后依然可以保持這條指令不會丟失,這是個什么地方呢?這個地方就是單片機(jī)內(nèi)部的只讀存儲器即ROM(READ ONLY MEMORY)。為什么稱它為只讀存儲器呢?剛才我們不是明明把兩個數(shù)字寫進(jìn)去了嗎?

原來在89C51中的ROM是一種電可擦除的ROM,稱為FLASH ROM,剛才我們是用的編程器,在特殊的條件下由外部設(shè)備對ROM進(jìn)行寫的操作,在單片機(jī)正常工作條件下,只能從那面讀,不能把數(shù)據(jù)寫進(jìn)去,所以我們還是把它稱為ROM。

幾個基本概念

1、數(shù)的本質(zhì)和物理現(xiàn)象

我們知道,計算機(jī)可以進(jìn)行數(shù)學(xué)運算,這令我們非常難以理解,計算機(jī)嗎,我們雖不了解它的組成,但它們只是一些電子元器件,怎么可以進(jìn)行數(shù)學(xué)運算呢?我們做數(shù)學(xué)題如37+45是這樣做的,先在紙上寫37,然后在下面寫45,然后大腦運算,最后寫出結(jié)果,運算的原材料:37、45和結(jié)果:82都是寫在紙上的,計算機(jī)中又是放在什么地方呢?

為了解決這個問題,先讓我們做一個實驗:這里有一盞燈,我們知道燈要么亮,要么不亮,就有兩種狀態(tài),我們可以用’0’和’1’來代替這兩種狀態(tài),規(guī)定亮為’1’,不亮為’0’。現(xiàn)在放上兩盞燈,一共有幾種狀態(tài)呢?我們列表來看一下:

請大家自己寫上3盞燈的情況000 001 010 011 100 101 110 111我們來看,這個000,001,101 不就是我們學(xué)過的的二進(jìn)制數(shù)嗎?本來,燈的亮和滅只是一種物理現(xiàn)象,可當(dāng)我們把它們按一定的順序排好后,燈的亮和滅就代表了數(shù)字了。讓我們再抽象一步,燈為什么會亮呢?是因為輸出電路輸出高電平,給燈通了電。因此,燈亮和滅就可以用電路的輸出是高電平還是低電平來替代了。這樣,數(shù)字就和電平的高、低聯(lián)系上了。(請想一下,我們還看到過什么樣的類似的例子呢?(海軍之)燈語、旗語,電報,甚至紅、綠燈)。有助于對電平理解的文章:CPU怎么識別我們寫的代碼?

2、位的含義

通過上面的實驗我們已經(jīng)知道:一盞燈亮或者說一根線的電平的高低,可以代表兩種狀態(tài):0和1。實際上這就是一個二進(jìn)制位,因此我們就把一根線稱之為一“位”,用BIT表示。

3、字節(jié)的含義

一根線可以表示0和1,兩根線可以表達(dá)00,01,10,11四種狀態(tài),也就是可以表達(dá)0到3,而三根可以表達(dá)0~7,計算機(jī)中通常用8根線放在一起,同時計數(shù),就可以表示0-255一共256種狀態(tài)。這8根線或者8位就稱之為一個字節(jié)(BYTE)。

存儲器的工作原理

1、存儲器構(gòu)造

30871a5a-ec70-11ed-90ce-dac502259ad0.jpg


存儲器就是用來存放數(shù)據(jù)的地方。它是利用電平的高低來存放數(shù)據(jù)的,也就是說,它存放的實際上是電平的高、低,而不是我們所習(xí)慣認(rèn)為的1234這樣的數(shù)字,這樣,我們的一個謎團(tuán)就解開了,計算機(jī)也沒什么神秘的嗎。

如上圖左所示:一個存儲器就象一個個的小抽屜,一個小抽屜里有八個小格子,每個小格子就是用來存放“電荷”的,電荷通過與它相連的電線傳進(jìn)來或釋放掉,至于電荷在小格子里是怎樣存的,就不用我們操心了,你可以把電線想象成水管,小格子里的電荷就象是水,那就好理解了。存儲器中的每個小抽屜就是一個放數(shù)據(jù)的地方,我們稱之為一個“單元”。

有了這么一個構(gòu)造,我們就可以開始存放數(shù)據(jù)了,想要放進(jìn)一個數(shù)據(jù)12,也就是00001100,我們只要把第二號和第三號小格子里存滿電荷,而其它小格子里的電荷給放掉就行了(看上圖右)。可是問題出來了,看上圖右,一個存儲器有好多單元,線是并聯(lián)的,在放入電荷的時候,會將電荷放入所有的單元中,而釋放電荷的時候,會把每個單元中的電荷都放掉,這樣的話,不管存儲器有多少個單元,都只能放同一個數(shù),這當(dāng)然不是我們所希望的,因此,要在結(jié)構(gòu)上稍作變化,看上圖右,在每個單元上有個控制線,我想要把數(shù)據(jù)放進(jìn)哪個單元,就把一個信號給這個單元的控制線,這個控制線就把開關(guān)打開,這樣電荷就可以自由流動了,而其它單元控制線上沒有信號,所以開關(guān)不打開,不會受到影響,這樣,只要控制不同單元的控制線,就可以向各單元寫入不同的數(shù)據(jù)了,同樣,如果要從某個單元中取數(shù)據(jù),也只要打開相應(yīng)的控制開關(guān)就行了。

2、存儲器譯碼

那么,我們怎樣來控制各個單元的控制線呢?這個還不簡單,把每個單元的控制線都引到集成電路的外面不就行了嗎?事情可沒那么簡單,一片27512存儲器中有65536個單元,把每根線都引出來,這個集成電路就得有6萬多個腳?不行,怎么辦?要想法減少線的數(shù)量。我們有一種方法稱這為譯碼,簡單介紹一下:一根線可以代表2種狀態(tài),2根線可以代表4種狀態(tài),3根線可以代表幾種,256種狀態(tài)又需要幾根線代表?8種,8根線,所以65536種狀態(tài)我們只需要16根線就可以代表了。

3、存儲器的選片及總線的概念

至此,譯碼的問題解決了,讓我們再來關(guān)注另外一個問題。送入每個單元的八根線是用從什么地方來的呢?它就是從計算機(jī)上接過來的,一般地,這八根線除了接一個存儲器之外,還要接其它的器件。這樣問題就出來了,這八根線既然不是存儲器和計算機(jī)之間專用的,如果總是將某個單元接在這八根線上,就不好了,比如這個存儲器單元中的數(shù)值是0FFH另一個存儲器的單元是00H,那么這根線到底是處于高電平,還是低電平?豈非要打架看誰歷害了?所以我們要讓它們分離。辦法當(dāng)然很簡單,當(dāng)外面的線接到集成電路的引腳進(jìn)來后,不直接接到各單元去,中間再加一組開關(guān)就行了。平時我們讓開關(guān)打開著,如果確實是要向這個存儲器中寫入數(shù)據(jù),或要從存儲器中讀出數(shù)據(jù),再讓開關(guān)接通就行了。這組開關(guān)由三根引線選擇:讀控制端、寫控制端和片選端。要將數(shù)據(jù)寫入片中,先選中該片,然后發(fā)出寫信號,開關(guān)就合上了,并將傳過來的數(shù)據(jù)(電荷)寫入片中。如果要讀,先選中該片,然后發(fā)出讀信號,開關(guān)合上,數(shù)據(jù)就被送出去了。讀和寫信號同時還接入到另一個存儲器,但是由于片選端不同,所以雖有讀或?qū)懶盘枺珱]有片選信號,所以另一個存儲器不會“誤會”而開門,造成沖突。那么會不同時選中兩片芯片呢?只要是設(shè)計好的系統(tǒng)就不會,因為它是由計算控制的,而不是我們?nèi)藖砜刂频模绻娴某霈F(xiàn)同時出現(xiàn)選中兩片的情況,那就是電路出了故障了,這不在我們的討論之列。

從上面的介紹中我們已經(jīng)看到,用來傳遞數(shù)據(jù)的八根線并不是專用的,而是很多器件大家共用的,所以我們稱之為數(shù)據(jù)總線,總線英文名為BUS,總即公交車道,誰也可以走。而十六根地址線也是連在一起的,稱之為地址總線。

審核編輯:湯梓紅

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

    關(guān)注

    6040

    文章

    44592

    瀏覽量

    636901
  • FlaSh
    +關(guān)注

    關(guān)注

    10

    文章

    1640

    瀏覽量

    148299
  • 存儲器
    +關(guān)注

    關(guān)注

    38

    文章

    7518

    瀏覽量

    164083
  • ROM
    ROM
    +關(guān)注

    關(guān)注

    4

    文章

    575

    瀏覽量

    85863
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    2894

    瀏覽量

    88219

原文標(biāo)題:單片機(jī)是如何工作的?

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    從事單片機(jī)工作好找嗎?請指教!

    從事單片機(jī)工作好找嗎?需要那些經(jīng)驗啊.請指教!我好學(xué)習(xí).
    發(fā)表于 09-08 13:39

    現(xiàn)在從事單片機(jī)工作前景怎么樣

    現(xiàn)在從事單片機(jī)工作前景怎么樣,大家發(fā)表一下意見。
    發(fā)表于 12-07 11:50

    單片機(jī)工作電壓是5v的原因

    為什么很多單片機(jī)工作電壓是5v?
    發(fā)表于 02-05 07:39

    為什么很多單片機(jī)工作電壓都選擇5V而不是3.3V?

    單片機(jī)工作電壓主要有哪幾種?為什么很多單片機(jī)工作電壓是5v?為什么很多單片機(jī)工作電壓都選擇5V而不是3.3V?
    發(fā)表于 07-07 06:37

    請問一下為什么很多單片機(jī)工作電壓是5v?

    請問一下為什么很多單片機(jī)工作電壓是5v?
    發(fā)表于 09-18 06:48

    為什么很多單片機(jī)工作電壓是5v

    為什么很多單片機(jī)工作電壓是5v?為什么很多單片機(jī)工作電壓是5v或者3.3V?
    發(fā)表于 09-18 09:05

    請問為什么很多單片機(jī)工作電壓是5v?

    請問為什么很多單片機(jī)工作電壓是5v?
    發(fā)表于 10-29 06:43

    為什么很多單片機(jī)工作電壓是5v?

    因為大多數(shù)芯片都是5V的TTL電平,要做到電平兼容,電平匹配,避免要電平轉(zhuǎn)換操作,所有很多單片機(jī)工作電壓都是5V。早期(196x)的晶體管電路(TTL)單管的壓降是0.7v。 一個電路里經(jīng)常有多個晶體管串聯(lián)。
    發(fā)表于 03-26 09:57 ?1.4w次閱讀

    為什么很多單片機(jī)工作電壓是5v

    因為大多數(shù)芯片都是5V的TTL電平,要做到電平兼容,電平匹配,避免要電平轉(zhuǎn)換操作,所以很多單片機(jī)工作電壓都是5V。
    的頭像 發(fā)表于 02-16 14:53 ?3741次閱讀
    為什么很多<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>電壓是5v

    為什么很多單片機(jī)工作電壓是5V?

    因為大多數(shù)芯片都是5V的TTL電平,要做到電平兼容,電平匹配,避免要電平轉(zhuǎn)換操作,所以很多單片機(jī)工作電壓都是5V。
    發(fā)表于 01-23 08:42 ?8次下載
    為什么很多<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>電壓是5V?

    單片機(jī)工作頻率及輸出驅(qū)動能力資料下載

    電子發(fā)燒友網(wǎng)為你提供單片機(jī)工作頻率及輸出驅(qū)動能力資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考設(shè)計、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發(fā)表于 03-27 08:40 ?5次下載
    <b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>頻率及輸出驅(qū)動能力資料下載

    單片機(jī)工作狀態(tài)及其狀態(tài)遷移資料下載

    電子發(fā)燒友網(wǎng)為你提供單片機(jī)工作狀態(tài)及其狀態(tài)遷移資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考設(shè)計、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發(fā)表于 04-14 08:40 ?10次下載
    <b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>狀態(tài)及其狀態(tài)遷移資料下載

    究竟是什么讓很多單片機(jī)工作電壓是5V?資料下載

    電子發(fā)燒友網(wǎng)為你提供究竟是什么讓很多單片機(jī)工作電壓是5V?資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考設(shè)計、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發(fā)表于 04-23 08:45 ?2次下載
    究竟是什么讓很多<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>電壓是5V?資料下載

    為什么很多單片機(jī)工作電壓是5V?

    大多數(shù)芯片都是5V的TTL電平,要做到電平兼容,電平匹配,避免要電平轉(zhuǎn)換操作,所有很多單片機(jī)工作電壓都是5V。
    發(fā)表于 02-08 16:33 ?0次下載
    為什么很多<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>電壓是5V?

    為什么很多單片機(jī)工作電壓是5v?

    究竟是什么讓很多單片機(jī)工作電壓是5V? 5V來自于TTL電平。 5為True,0為False,之后用了壓降更低的PN節(jié),衍生出了3.3這個電平。
    的頭像 發(fā)表于 04-06 09:34 ?1519次閱讀
    為什么很多<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>工作</b>電壓是5v?
    主站蜘蛛池模板: 免费的黄视频| 天天操天天谢| 欧美zoozzooz在线观看| 99视频热| 国产黄色视屏| 国产小视频在线播放| 天天曰天天爽| 夜夜夜爽| 成人伊在线影院| 国产精品青草久久| 加勒比色| 激情午夜婷婷| 成人欧美一区二区三区视频 | 成人啪啪免费视频| 亚洲免费视频一区二区三区| 国产福利99| 国产伦一区二区三区免费| 大量国产后进翘臀视频| 在线观看日本免费视频大片一区| 日本免费一区二区视频| 亚洲色图 在线视频| 在线观看免费视频国产| 午夜三级毛片| 免费网站色| a级黄色毛片三个搞一| 成人看的一级毛片| 天天干夜夜骑| 人人干人人玩| 日本高清视频一区| 手机在线完整视频免费观看| 男人的j桶女人的j视频| 天堂成人| 日本三级免费看| 国产三及| bt天堂资源在线种子| 91精品国产91久久久久久青草| 99视频网址| 久久精彩免费视频| 午夜爽视频| 亚洲欧美国产视频| 欧美一级视频高清片|