這篇文章主要介紹了C/C++函數(shù)庫(kù)調(diào)用與系統(tǒng)調(diào)用的區(qū)別有哪些,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供邵武網(wǎng)站建設(shè)、邵武做網(wǎng)站、邵武網(wǎng)站設(shè)計(jì)、邵武網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、邵武企業(yè)網(wǎng)站模板建站服務(wù),十年邵武做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
函數(shù)庫(kù)調(diào)用是語(yǔ)言或應(yīng)用程序的一部分,而系統(tǒng)調(diào)用是操作系統(tǒng)的一部分。
系統(tǒng)調(diào)用是在操作系統(tǒng)內(nèi)核發(fā)現(xiàn)的一個(gè)“trap”或中斷后進(jìn)行的。
函數(shù)庫(kù)調(diào)用vs.系統(tǒng)調(diào)用
函數(shù)庫(kù)調(diào)用 | 系統(tǒng)調(diào)用 |
---|---|
在所有的ANSI C編譯器版本中,C函數(shù)庫(kù)是相同的 | 各個(gè)操作系統(tǒng)的系統(tǒng)調(diào)用是不同的 |
它調(diào)用函數(shù)庫(kù)中的一個(gè)程序 | 它調(diào)用系統(tǒng)內(nèi)核的服務(wù) |
與用戶程序相聯(lián)系 | 是操作系統(tǒng)的一個(gè)進(jìn)入點(diǎn) |
在用戶地址空間執(zhí)行 | 在內(nèi)核地址空間執(zhí)行 |
它的運(yùn)行時(shí)間屬于“用戶”時(shí)間 | 它的運(yùn)行時(shí)間屬于“系統(tǒng)”時(shí)間 |
屬于過(guò)程調(diào)用,開銷較小 | 需要在切換到內(nèi)核上下文環(huán)境然后切換回來(lái),開銷較大 |
在C函數(shù)庫(kù)libc中有大約300個(gè)程序 | 在UNIx中有大約90個(gè)系統(tǒng)調(diào)用(MS-DOS中少一些) |
記錄于UNIX OS手冊(cè)的第三節(jié) | 記錄于UNIX OS手冊(cè)的第二節(jié) |
典型的C函數(shù)庫(kù)調(diào)用:system,fprintf,malloc | 典型的系統(tǒng)調(diào)用:chidr,fork,write,brk |
庫(kù)函數(shù)調(diào)用通常比行內(nèi)展開的代碼慢,因?yàn)樗枰冻龊瘮?shù)調(diào)用的開銷。但系統(tǒng)調(diào)用比庫(kù)函數(shù)調(diào)用還要慢很多,因?yàn)樗枰焉舷挛沫h(huán)境切換到內(nèi)核模式。在SPARC工作站上,對(duì)一個(gè)庫(kù)函數(shù)調(diào)用進(jìn)行記時(shí),結(jié)果大約是半微秒。系統(tǒng)調(diào)用所需要的時(shí)間大約是庫(kù)函數(shù)調(diào)用的70倍(35微秒)。純粹從性能上考慮,你應(yīng)該盡可能地減少系統(tǒng)調(diào)用的數(shù)量。但是,許多C函數(shù)庫(kù)中的程序通過(guò)系統(tǒng)調(diào)用來(lái)實(shí)現(xiàn)功能。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“C/C++函數(shù)庫(kù)調(diào)用與系統(tǒng)調(diào)用的區(qū)別有哪些”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!