C++鏈接器工作原理詳解
當(dāng)文件見(jiàn)過(guò)編譯后就需要進(jìn)行一個(gè)鏈接的操作接下來(lái)我們就說(shuō)說(shuō)什么是鏈接
接下來(lái)我展示一些例子:
#include<iostream> void Log(const char* message) { std::cout << message << std::endl; } int Multiply(int a, int b) { Log("Multiply"); return a * b; }
這是一段非常簡(jiǎn)單的代碼,它有一個(gè)Log函數(shù)和一個(gè)Multiply函數(shù)其中Multiply調(diào)用了Log函數(shù)然后返回a*b的值。發(fā)現(xiàn)沒(méi)用它沒(méi)有主函數(shù)main,所以他其實(shí)并不是一個(gè)完整的程序,首先我們要意思到,編譯是兩個(gè)階段的編譯個(gè)鏈接,接下來(lái)哦我們用這段代碼來(lái)展示一下他們的區(qū)別。
這段代碼復(fù)制到vs中,如果我們按ctrl+F7可以發(fā)現(xiàn)這段代碼他是不報(bào)啥錯(cuò)的,一切是正常的,以為編譯生成了obj目標(biāo)文件。
那么如果我們是右鍵生成,可以發(fā)現(xiàn)會(huì)有一個(gè)LNK的報(bào)錯(cuò),這個(gè)就是鏈接錯(cuò)誤。
那怎么解決這個(gè)錯(cuò)誤呢?我們添加一個(gè)main函數(shù)就可以了(因?yàn)槲覀內(nèi)鄙倭巳肟诤瘮?shù))
接著我們把這段代碼補(bǔ)全,然后運(yùn)行一下,可以看到代碼是可以正確運(yùn)行的。
我們假設(shè)有很多的cpp文件,所以就需要一個(gè)log日志文件,把log函數(shù)放到log.ccpp中,然后運(yùn)行一下,可以看到成功編譯了。
接下來(lái),我看看一個(gè)非常有意思的錯(cuò)誤,改成下面這段代碼.
log.cpp #include<iostream> void Logr(const char* message) { std::cout << message << std::endl; } Multiply.cpp #include<iostream> void Log(const char* message); int Multiply(int a, int b) { //Log("Multiply"); return a * b; } int main() { std::cout << Multiply(8, 5) << std::endl; std::cin.get(); }
這樣我們一看就知道這段代碼是可以正常編譯的,因?yàn)槲覀儼裭og函數(shù)注釋了,但是如果我們是注釋的Multiply這個(gè)調(diào)用的?你們猜猜這個(gè)還可以正常編譯嗎?看看結(jié)果,沒(méi)錯(cuò)他報(bào)錯(cuò)了(鏈接錯(cuò)誤),按正常來(lái)說(shuō)我們注釋了Multiply這個(gè)調(diào)用,那log不是也就沒(méi)用到(log在Multiply函數(shù)中),那應(yīng)該是對(duì)的才對(duì)??!并不是這樣的,因?yàn)樵谖募R中,雖然我們沒(méi)用用到Multiply函數(shù),但是從技術(shù)上來(lái)說(shuō)我們是可能在其他地方用到他的,所以連接器就需要鏈接他就會(huì)報(bào)錯(cuò)(因?yàn)檎也坏铰铮敲粗灰嬖V鏈接器,Multiply不會(huì)再其他地方用到只會(huì)再這個(gè)里面用到就可以解決這個(gè)問(wèn)題了,怎么解決呢?加一個(gè)static(這意味著Multiply函數(shù)只聲明在Multiply.cpp中),我們?cè)囋?。好了,不?bào)錯(cuò)了,很神奇吧!總的來(lái)說(shuō)就是如果編譯器找不到確切的函數(shù)定義,就會(huì)有鏈接錯(cuò)誤
以上就是C++鏈接器工作原理詳解的詳細(xì)內(nèi)容,更多關(guān)于C++鏈接器工作原理的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C語(yǔ)言進(jìn)階二叉樹的基礎(chǔ)與銷毀及層序遍歷詳解
朋友們好,這篇播客我們繼續(xù)C++的初階學(xué)習(xí),現(xiàn)在對(duì)我們對(duì)C++的二叉樹基礎(chǔ)oj與二叉樹銷毀和層序遍歷進(jìn)行練習(xí),讓我們相互學(xué)習(xí),共同進(jìn)步2022-06-06優(yōu)先隊(duì)列(priority_queue)的C語(yǔ)言實(shí)現(xiàn)代碼
本文簡(jiǎn)要介紹一種基于數(shù)組二叉堆實(shí)現(xiàn)的優(yōu)先隊(duì)列,定義的數(shù)據(jù)結(jié)構(gòu)和實(shí)現(xiàn)的函數(shù)接口說(shuō)明如下2013-10-10C++圖論之Bellman-Ford算法和SPFA算法的實(shí)現(xiàn)
貝爾曼-福特算法(Bellman-Ford)是由理查德·貝爾曼和萊斯特·福特創(chuàng)立的,求解單源最短路徑問(wèn)題的一種算法。SPFA 算法是 Bellman-Ford算法 的隊(duì)列優(yōu)化算法的別稱,通常用于求含負(fù)權(quán)邊的單源最短路徑。本文將詳解兩個(gè)算法的實(shí)現(xiàn),需要的可以參考一下2022-06-06深入探討:main函數(shù)執(zhí)行完畢后,是否可能會(huì)再執(zhí)行一段代碼?
本篇文章是對(duì)main函數(shù)執(zhí)行完畢后,是否可能會(huì)再執(zhí)行一段代碼,進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07