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

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

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

當(dāng)文件見過編譯后就需要進(jìn)行一個鏈接的操作接下來我們就說說什么是鏈接

接下來我展示一些例子:

#include<iostream>
 
void Log(const char* message)
{
	std::cout << message << std::endl;
}
 
int Multiply(int a, int b)
{
	Log("Multiply");
	return a * b;
}

這是一段非常簡單的代碼,它有一個Log函數(shù)和一個Multiply函數(shù)其中Multiply調(diào)用了Log函數(shù)然后返回a*b的值。發(fā)現(xiàn)沒用它沒有主函數(shù)main,所以他其實并不是一個完整的程序,首先我們要意思到,編譯是兩個階段的編譯個鏈接,接下來哦我們用這段代碼來展示一下他們的區(qū)別。

這段代碼復(fù)制到vs中,如果我們按ctrl+F7可以發(fā)現(xiàn)這段代碼他是不報啥錯的,一切是正常的,以為編譯生成了obj目標(biāo)文件。

那么如果我們是右鍵生成,可以發(fā)現(xiàn)會有一個LNK的報錯,這個就是鏈接錯誤。

那怎么解決這個錯誤呢?我們添加一個main函數(shù)就可以了(因為我們?nèi)鄙倭巳肟诤瘮?shù))

接著我們把這段代碼補(bǔ)全,然后運(yùn)行一下,可以看到代碼是可以正確運(yùn)行的。

我們假設(shè)有很多的cpp文件,所以就需要一個log日志文件,把log函數(shù)放到log.ccpp中,然后運(yùn)行一下,可以看到成功編譯了。

接下來,我看看一個非常有意思的錯誤,改成下面這段代碼.

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();
}

這樣我們一看就知道這段代碼是可以正常編譯的,因為我們把log函數(shù)注釋了,但是如果我們是注釋的Multiply這個調(diào)用的?你們猜猜這個還可以正常編譯嗎?看看結(jié)果,沒錯他報錯了(鏈接錯誤),按正常來說我們注釋了Multiply這個調(diào)用,那log不是也就沒用到(log在Multiply函數(shù)中),那應(yīng)該是對的才對啊!并不是這樣的,因為在文件匯中,雖然我們沒用用到Multiply函數(shù),但是從技術(shù)上來說我們是可能在其他地方用到他的,所以連接器就需要鏈接他就會報錯(因為找不到嘛),那么只要告訴鏈接器,Multiply不會再其他地方用到只會再這個里面用到就可以解決這個問題了,怎么解決呢?加一個static(這意味著Multiply函數(shù)只聲明在Multiply.cpp中),我們試試。好了,不報錯了,很神奇吧!總的來說就是如果編譯器找不到確切的函數(shù)定義,就會有鏈接錯誤

以上就是C++鏈接器工作原理詳解的詳細(xì)內(nèi)容,更多關(guān)于C++鏈接器工作原理的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

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

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

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

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

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

    C語言進(jìn)階二叉樹的基礎(chǔ)與銷毀及層序遍歷詳解

    朋友們好,這篇播客我們繼續(xù)C++的初階學(xué)習(xí),現(xiàn)在對我們對C++的二叉樹基礎(chǔ)oj與二叉樹銷毀和層序遍歷進(jìn)行練習(xí),讓我們相互學(xué)習(xí),共同進(jìn)步
    2022-06-06
  • 優(yōu)先隊列(priority_queue)的C語言實現(xiàn)代碼

    優(yōu)先隊列(priority_queue)的C語言實現(xiàn)代碼

    本文簡要介紹一種基于數(shù)組二叉堆實現(xiàn)的優(yōu)先隊列,定義的數(shù)據(jù)結(jié)構(gòu)和實現(xiàn)的函數(shù)接口說明如下
    2013-10-10
  • VC++中圖像處理類CBitmap的用法

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

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

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

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

    C++圖論之Bellman-Ford算法和SPFA算法的實現(xiàn)

    貝爾曼-福特算法(Bellman-Ford)是由理查德·貝爾曼和萊斯特·福特創(chuàng)立的,求解單源最短路徑問題的一種算法。SPFA 算法是 Bellman-Ford算法 的隊列優(yōu)化算法的別稱,通常用于求含負(fù)權(quán)邊的單源最短路徑。本文將詳解兩個算法的實現(xiàn),需要的可以參考一下
    2022-06-06
  • 深入探討:main函數(shù)執(zhí)行完畢后,是否可能會再執(zhí)行一段代碼?

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

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

    c語言的注釋定界符詳解

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

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

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

最新評論