第1章 從機器碼到開發(fā)語言(X86匯編教程)
匯編語言可能是所有開發(fā)語言中見效最慢的了,一般學匯編都是學習很久才
本文引用地址:http://www.ex-cimer.com/article/201612/324263.htm會開始教怎么開發(fā)第一個程序,前邊一堆都是講電腦原理,因為匯編是最底層的.所以
需要一堆電腦原理知識才能學習.所以我不會在一開始就教開發(fā).另外學習匯編最好是
放下你以前對電腦的一些看法...
電腦是一臺計算機,顯示在屏幕上的東西全都是通過數(shù)學計算得來的.
CPU(中央處理器),是電腦的計算單元,電腦的計算工作都通過CPU來完成.如
同人類的大腦,CPU直接或間接連接著電腦的所有硬件,CPU從內(nèi)存里讀取機器碼,并解
析機器碼的意思,對電腦的一切進行支配.
那么什么是機器碼呢?那是一些2進制指令的集合.類似于這樣:
101110000001000010001001
這就是2進制指令,人們叫它:比特(bit)
CPU通過1秒鐘解析無數(shù)比特,對電腦進行支配.
是不是覺得有些頭暈?這些數(shù)據(jù)有一個單位,叫做字節(jié)(byte).一個字節(jié)又8個
比特組成.當然字節(jié)之上還有很多單位,那些咱們暫且不談.下面我們把那組數(shù)據(jù)分成
字節(jié)單位的:
10111000 00010000 10001001
這樣,看起來順眼多了是吧?但是這樣仍然還是很麻煩,一個好的程序,往往有
幾千字節(jié),這要是代碼出了錯誤,程序員修改的時候一堆1和0把眼睛都閃瞎了,還怎么
來修改?
于是,程序員們編寫了一個程序,世界上第一個匯編編譯器,它有什么作用呢?
它呢,能把一句英文寫的指令轉(zhuǎn)換成幾個字節(jié)組成的機器碼.這樣:
MOV [0000],1234
也就是說,人們用英文字母代替了那一堆1和0組成的數(shù)字.那之后以行作為單
位的指令就開始出現(xiàn)了,在這之前,指令都是一個字節(jié)一個字節(jié)排列在內(nèi)存里的,用眼
睛去看就是一堆數(shù)字,完全不知道哪個字節(jié)是一條指令的開頭哪個又是結(jié)尾.
后來人們發(fā)現(xiàn).可以用一行代碼代替幾十行匯編代碼,能夠使開發(fā)更加輕松.
于是程序員開發(fā)了一個程序,能夠把一行代碼轉(zhuǎn)換成幾十行匯編代碼再轉(zhuǎn)換成機器碼.
于是出現(xiàn)了高級語言.與匯編相比,高級語言執(zhí)行效率會低一點,同樣功能的代碼執(zhí)行
起來比匯編慢了一大截,但是開發(fā)起來更加輕松了.同樣的事情在匯編中需要幾十行代
碼才能完成,用高級語言則幾行代碼搞定(雖然執(zhí)行起來速度比匯編的代碼慢).
不管什么開發(fā)語言,想要讓電腦能夠識別就必須要轉(zhuǎn)換成2進制的機器碼字節(jié)
.高級語言一行代碼能做很多次沒錯,但是轉(zhuǎn)換成機器碼以后,一行高級語言轉(zhuǎn)出來的
機器碼都是幾十上百字節(jié)的.而匯編語言轉(zhuǎn)出來的機器碼往往只有幾個字節(jié)而已.所以
高級語言與匯編,一個是在開發(fā)的時候快,適合編寫一些不需要高速計算的程序,一個
是在用的時候快,適合編寫一些常用的東西,比如一個程序,一秒鐘會被調(diào)用幾萬次,那
這個程序最好是匯編寫的,不然會很卡.
評論