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


對于循環語句,其實也是一樣的,也是通過跳轉指令來實現。


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


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

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