高級語言中的語句在匯編中是如何實現(xiàn)的
我們都知道對于c語言來說,它是需要先轉(zhuǎn)換成匯編語言,然后再生成機(jī)器語言的。那么在c語言中,各種條件語句,各種表達(dá)式的計算,在匯編中是何如實現(xiàn)的呢?今天我們就來講解一下。
匯編語言
匯編語言是由包含用助記符如 ADD、MOV、SUB 和 CALL 書寫的語句。匯編語言與機(jī)器語言是一對一(one-to-one)的關(guān)系:每一條匯編語言指令對應(yīng)一條機(jī)器語言指令。
因為匯編語言和機(jī)器語言是綁定的,而不同機(jī)器語言是不同的,因此,匯編語言是不可移植的,而高級語言是可移植的,這也是為什么人們更多地用高級語言來開發(fā)應(yīng)用的一個原因。
跳轉(zhuǎn)指令
跳轉(zhuǎn)指令可以說是實現(xiàn)高級語言條件的核心,因為一切條件判斷或者循環(huán)語句,底層都是通過跳轉(zhuǎn)指令來實現(xiàn)的。
在匯編語言中,我們可以通過設(shè)置標(biāo)號來實現(xiàn)語句的跳轉(zhuǎn),例如高級語言的if判斷,在匯編語言中,就可以這樣實現(xiàn)。


對于循環(huán)語句,其實也是一樣的,也是通過跳轉(zhuǎn)指令來實現(xiàn)。


在循環(huán)內(nèi)部,EAX 是 val1 的代理(替代品),對 val1 的引用必須要通過 EAX。JNL 的使用意味著 val1 和 val2 是有符號整數(shù)。
邏輯判斷的實現(xiàn)也是通過跳轉(zhuǎn)指令來實現(xiàn)的,具體如下。


通過上面的例子我們可以看出,無論是怎樣復(fù)雜的邏輯,無論是循環(huán)還是條件判斷,在底層匯編層,其實都是通過跳轉(zhuǎn)指令來實現(xiàn)的。
寄存器
我們都知道cpu本身只是用來計算的,它本身不保存數(shù)據(jù),但是因為cpu運算速度過快,高于內(nèi)存讀取速度,因此cpu設(shè)計了寄存器用來保存臨時數(shù)據(jù),而讀取它們的速度非常高效,大大提高了cpu的處理速度。

我們的高級語言轉(zhuǎn)換成匯編語言的時候,可能一條語句就會變成多條語句,因此我們經(jīng)常說c語言的語句不是原子的,因為它在匯編層可能會對應(yīng)多條語句,而多條語句并行的時候就會產(chǎn)生執(zhí)行順序的問題,這也是并發(fā)產(chǎn)生的原因。
總結(jié)
無論是指令還是數(shù)據(jù),都是通過寄存器來存儲和讀取的,正是有了寄存器,我們才可以非常方便地進(jìn)行數(shù)據(jù)的累加,進(jìn)行地址的變換,進(jìn)行數(shù)據(jù)的查找。
我們經(jīng)常說計算機(jī)只能識別01二進(jìn)制數(shù),是說cpu將二進(jìn)制編碼進(jìn)行了存儲和轉(zhuǎn)換,當(dāng)遇到特定的二進(jìn)制,它就對應(yīng)特定的操作。