多个cpp文件生成so_C++:C++的文件搜索路径
在做大型工程的時(shí)候,除了有C++語法知識(shí)之外,還要有工程能力。
最先要具備的能力是:
理解C++文件的編譯,鏈接過程。
明白C++頭文件的搜索路徑。
本文,介紹C++的文件搜索路徑。
對(duì)于C++文件來說,主要有兩種,一種是.h文件,一種是.cpp文件。
其中.h文件,相對(duì)來說,不那么重要。因?yàn)?cpp文件里會(huì)#include "a.h"一下,這樣.h文件會(huì)在預(yù)編譯階段被加入到.cpp中,實(shí)質(zhì)上,這是一種強(qiáng)制的替換。
誰來執(zhí)行這個(gè)替換呢?是gcc,這個(gè)編譯器。
gcc這個(gè)編譯器會(huì)先對(duì)代碼進(jìn)行編譯,甚至進(jìn)行代碼優(yōu)化,再進(jìn)行鏈接。
編譯的過程也分為幾個(gè)階段,但不重要,主要是cpp文件會(huì)被編譯成一個(gè)os文件。這是一個(gè)二進(jìn)制文件。每一個(gè)cpp文件要變成程序,就需要一個(gè)os文件。這個(gè)編譯的過程中,gcc會(huì)對(duì)C++代碼進(jìn)行代碼優(yōu)化,這個(gè)中間過程,可以看編譯原理之類的書,我目前在搞這些,枯燥無味,卻不得不做,因?yàn)樾阅芤_(dá)標(biāo)。
編譯完了,就會(huì)進(jìn)行鏈接:所謂的鏈接,就是把一些已經(jīng)存在的庫文件,鏈接到代碼中。這個(gè)過程可以理解為:gcc有的時(shí)候只有一些庫文件,也就是so文件。和它們的頭文件,為啥只有so,因?yàn)轭^文件給接口,so就能保護(hù)源代碼,從而使得程序可以以庫的形式賣出價(jià)格。這些庫文件的so要和我們自己寫的cpp文件生成的.so鏈接起來。大概就是so中有一個(gè)表,表示自己身體里有哪些代碼段對(duì)應(yīng)的二進(jìn)制,gcc就根據(jù)這個(gè)表,根據(jù)代碼的需要,把二進(jìn)制段拼湊起來。
最后鏈接完成的,就是exe文件,也就是可執(zhí)行文件。
題外話:動(dòng)態(tài)鏈接和靜態(tài)鏈接的區(qū)別在于,靜態(tài)鏈接是把庫文件打包復(fù)制一份到exe,而動(dòng)態(tài)鏈接是,可執(zhí)行文件運(yùn)行的時(shí)候,再去機(jī)子上的環(huán)境去尋找so,再構(gòu)建起來。
那么,知道了gcc是怎么編譯的了,問題就來了,一個(gè)cpp中會(huì)#include "a.h“,"a.h"中可能會(huì)有"b.h",也可能是"/tvm/b.h",那gcc怎么找b.h呢?
其實(shí)很簡單,對(duì)于#include<iostream>這種:
gcc就會(huì)直奔gcc -l 這個(gè)路徑指定的路徑下去找。
如果gcc -l沒有指定目錄,它就會(huì)去usr/local下去找。
如果還是找不到,就會(huì)去local/bin里面去找。
路徑可能是記錯(cuò)了,用的時(shí)候搜一下就好。
對(duì)于#include "hah.n"這種。
gcc就會(huì)在本目錄下搜索,搜索不到,才會(huì)和<iostream>按照同樣的邏輯去尋找。
總結(jié)
以上是生活随笔為你收集整理的多个cpp文件生成so_C++:C++的文件搜索路径的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: xrd精修教程_XRD精修系列干货 |
- 下一篇: java sendmessage函数_v