欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++鏈接器工作原理詳解

 更新時(shí)間:2024年02月11日 09:46:01   作者:我叫大健  
當(dāng)文件見(jiàn)過(guò)編譯后就需要進(jìn)行一個(gè)鏈接的操作接下來(lái)我們就說(shuō)說(shuō)什么是鏈接,本文給大家介紹了C++鏈接器是如何工作的,文章通過(guò)代碼示例和圖文介紹的非常詳細(xì),需要的朋友可以參考下

當(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++使用ifstream讀取文件內(nèi)容的示例詳解

    C++使用ifstream讀取文件內(nèi)容的示例詳解

    這篇文章主要為大家詳細(xì)介紹了C++如何使用ifstream讀取文件內(nèi)容的功能,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-03-03
  • C語(yǔ)言算法練習(xí)之佩奇借書

    C語(yǔ)言算法練習(xí)之佩奇借書

    這篇文章主要該大家分享C語(yǔ)言佩奇借書的練習(xí),文章主要通過(guò)描述佩奇借書的問(wèn)題然后確定程序框架將結(jié)果運(yùn)算出來(lái),下面來(lái)看詳細(xì)內(nèi)容吧,需要的朋友可以參考一下
    2022-03-03
  • C語(yǔ)言進(jìn)階二叉樹的基礎(chǔ)與銷毀及層序遍歷詳解

    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)代碼

    優(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-10
  • VC++中圖像處理類CBitmap的用法

    VC++中圖像處理類CBitmap的用法

    使用VC進(jìn)行圖像處理的時(shí)候,CBitmap類為我們提供了豐富的位圖處理函數(shù),本文總結(jié)了該類的相關(guān)函數(shù)和常用使用方法,包括加載位圖,顯示位圖,析構(gòu)CBitmap資源以及在內(nèi)存中保存位圖等內(nèi)容。
    2015-11-11
  • 探究c++虛表實(shí)現(xiàn)代碼

    探究c++虛表實(shí)現(xiàn)代碼

    虛表是一種利用程序語(yǔ)言實(shí)現(xiàn)的dynamic dispatch機(jī)制,或者說(shuō)runtime method binding機(jī)制,也就是我們說(shuō)的多態(tài)。本文簡(jiǎn)單探究虛表實(shí)現(xiàn)方法,一起看看吧
    2021-09-09
  • C++圖論之Bellman-Ford算法和SPFA算法的實(shí)現(xiàn)

    C++圖論之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í)行一段代碼?

    深入探討:main函數(shù)執(zhí)行完畢后,是否可能會(huì)再執(zhí)行一段代碼?

    本篇文章是對(duì)main函數(shù)執(zhí)行完畢后,是否可能會(huì)再執(zhí)行一段代碼,進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • c語(yǔ)言的注釋定界符詳解

    c語(yǔ)言的注釋定界符詳解

    在本文里小編給大家分享的是關(guān)于c語(yǔ)言的注釋定界符知識(shí)點(diǎn)詳解,需要的朋友們可以跟著學(xué)習(xí)下。
    2020-02-02
  • c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)

    c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)

    這篇文章主要介紹了c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07

最新評(píng)論