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