最近學習操作系統,有些東西不是很明白。c語言的庫函數有些是利用系統調用實現的,有些不是.我就想問下不是利用系統調用的那部分,在執行時硬件是怎么知道的呢?最后語言代碼被編譯成二進制,執行時仍然是由寄存器硬件什么執行的吧,既然沒利用系統調用,alu這些東西是怎么懂這些庫函數要求的操作是干嘛的???不是說系統調用是軟硬件的接口嗎?還有系統調用和驅動程序的關系是什么?
2 回答

慕標5832272
TA貢獻1966條經驗 獲得超4個贊
調用系統調用,代碼跳入內核態,可以執行任何指令,包括 受保護的指令
在用戶態,很多指令是受保護的,不能直接執行,或者執行會出錯。
例如 286 以上的X86 系列及兼容CPU
IO指令,就是受保護的。
實際上,硬件之間是通過總線相連的,并通過,IO讀寫指令,內存讀寫指令,DMA 方式,等等相互通訊。
程序代碼,被CPU取到,然后逐一執行
你寫的代碼,加載到內存后,操作系統用一個跳轉指令(call,jump,ret,iret 等等,都屬于跳轉類指令)
轉到你的代碼中執行的
除非受到保護的指令,都是可以在用戶態執行的,例如加法指令
數學庫
math.h,的函數
string.h
就大部分代碼都屬于,非保護指令
而 IO庫中的許多函數
例如
stdio.h
io.h
中的很多函數,都會調用系統調用的

料青山看我應如是
TA貢獻1772條經驗 獲得超8個贊
說說我的理解,C語言里的庫函數在編譯后都是生成的二進制指令,就包含了對硬件的操作。
舉一個例子,“+”是對兩個數進行操作,這兩個數既可能是數字,也可能是變量。如果是數字,在匯編語言中對于的就是立即數,編譯成二進制指令時直接利用無符號數加法指令就可以;而如果是變量的話,就會編譯成多條指令,首先是從內存里讀取變量到寄存器,再在寄存器中進行加法運算,運算完再保存到內存中。
- 2 回答
- 0 關注
- 1842 瀏覽
添加回答
舉報
0/150
提交
取消