• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            理清gcc、libc、libstdc++的關系

            Posted on 2019-03-18 14:27 Prayer 閱讀(571) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIXmakefile

            當你在linux下寫C/C++代碼的時候,是不是會遇到許多編譯鏈接的問題? 時不時報個glibc,gcc,g++等相關的錯誤? 很多時候都無從下手,而且比較混亂。 這也是編譯鏈接過程中經常出現的問題。

            這篇文章不是去介紹如何編譯鏈接,而是理清編譯鏈接過程中碰到的一些概念和出現的問題。尤其是,libc,glib,glibc,eglibc,libc++,libstdc++,gcc,g++。

            從libc說起。
            libc是Linux下原來的標準C庫,也就是當初寫hello world時包含的頭文件#include < stdio.h> 定義的地方。

            后來逐漸被glibc取代,也就是傳說中的GNU C Library,在此之前除了有libc,還有klibc,uclibc。現在只要知道用的最多的是glibc就行了,主流的一些linux操作系統如 Debian, Ubuntu,Redhat等用的都是glibc(或者其變種,下面會說到).

            那glibc都做了些什么呢? glibc是Linux系統中最底層的API,幾乎其它任何的運行庫都要依賴glibc。 glibc最主要的功能就是對系統調用的封裝,你想想看,你怎么能在C代碼中直接用fopen函數就能打開文件? 打開文件最終還是要觸發系統中的sys_open系統調用,而這中間的處理過程都是glibc來完成的。這篇文章詳細介紹了glibc是如何與上層應用程序和系統調用交互的。除了封裝系統調用,glibc自身也提供了一些上層應用函數必要的功能,如string,malloc,stdlib,linuxthreads,locale,signal等等。

            好了,那eglibc又是什么? 這里的e是Embedded的意思,也就是前面說到的變種glibc。eglibc的主要特性是為了更好的支持嵌入式架構,可以支持不同的shell(包括嵌入式),但它是二進制兼容glibc的,就是說如果你的代碼之前依賴eglibc庫,那么換成glibc后也不需要重新編譯。ubuntu系統用的就是eglibc(而不是glibc),不信,你執行 ldd –version 或者 /lib/i386-linux-gnu/libc.so.6
            (64位系統運行/lib/x86_64-linux-gnu)看看,便會顯示你系統中eglibc/glibc的版本信息。 這里提到了libc.so.6,這個文件就是eglibc/glibc編譯后的生成庫文件。

            還有一個glib看起來也很相似,那它又是什么呢?glib也是個c程序庫,不過比較輕量級,glib將C語言中的數據類型統一封裝成自己的數據類型,提供了C語言常用的數據結構的定義以及處理函數,有趣的宏以及可移植的封裝等(注:glib是可移植的,說明你可以在linux下,也可以在windows下使用它)。那它跟glibc有什么關系嗎?其實并沒有,除非你的程序代碼會用到glib庫中的數據結構或者函數,glib庫在ubuntu系統中并不會默認安裝(可以通過apt-get install libglib2.0-dev手動安裝),著名的GTK+和Gnome底層用的都是glib庫。想更詳細了解glib? 可以參考這里

            看到這里,你應該知道這些庫有多重要了吧? 你寫的C代碼在編譯的過程中有可能出現明明是這些庫里面定義的變,卻量還會出現’Undefined’, ‘Unreference’等錯誤,這時候你可能會懷疑是不是這些庫出問題了? 是不是該動手換個gilbc/eglibc了? 這里強調一點,在你準備更換/升級這些庫之前,你應該好好思考一下,你真的要更換/升級嗎?你要知道你自己在做什么!你要時刻知道glibc/eglibc的影響有多大,不管你之前部署的什么程序,linux系統的ls,cd,mv,ps等等全都得依賴它,很多人在更換/升級都有過慘痛的教訓,甚至讓整個系統奔潰無法啟動。所以,強烈不建議更換/升級這些庫!

            當然如果你寫的是C++代碼,還有兩個庫也要非常重視了,libc++/libstdc++,這兩個庫有關系嗎?有。兩個都是C++標準庫。libc++是針對clang編譯器特別重寫的C++標準庫,那libstdc++自然就是gcc的事兒了。libstdc++與gcc的關系就像clang與libc++. 其中的區別這里不作詳細介紹了。

            再說說libstdc++,glibc的關系。 libstdc++與gcc是捆綁在一起的,也就是說安裝gcc的時候會把libstdc++裝上。 那為什么glibc和gcc沒有捆綁在一起呢?
            相比glibc,libstdc++雖然提供了c++程序的標準庫,但它并不與內核打交道。對于系統級別的事件,libstdc++首先是會與glibc交互,才能和內核通信。相比glibc來說,libstdc++就顯得沒那么基礎了。

            說完了這些庫,這些庫最終都是拿來干嘛的?當然是要將它們與你的程序鏈接在一起! 這時候就不得不說說gcc了(當然還有前文提到的clang以及llvm等編譯器,本文就不細說它們的區別了)。

            你寫的C代碼.c文件通過gcc首先轉化為匯編.S文件,之后匯編器as將.S文件轉化為機器代碼.o文件,生成的.o文件再與其它.o文件,或者之前提到的libc.so.6庫文件通過ld鏈接器鏈接在一塊生成可執行文件。當然,在你編譯代碼使用gcc的時候,gcc命令已經幫你把這些細節全部做好了。

            那g++是做什么的? 慢慢說來,不要以為gcc只能編譯C代碼,g++只能編譯c++代碼。 后綴為.c的,gcc把它當作是C程序,而g++當作是c++程序;后綴為.cpp的,兩者都會認為是c++程序,注意,雖然c++是c的超集,但是兩者對語法的要求是有區別的。在編譯階段,g++會調用gcc,對于c++代碼,兩者是等價的,但是因為gcc命令不能自動和C++程序使用的庫聯接,需要這樣,gcc -lstdc++, 所以如果你的Makefile文件并沒有手動加上libstdc++庫,一般就會提示錯誤,要求你安裝g++編譯器了。

            好了,就說到這,理清這些庫與編譯器之間的關系,相信會對你解決編譯鏈接過程中遇到的錯誤起到一點幫助。

            如果你的編譯器不支持一些新的C/C++特性,想升級gcc/g++, 這里也給出一個基于ubuntu系統的參考方法。

            添加ppa

            sudo add-apt-repository ppa:ubuntu-toolchain-r/test sudo apt-get update 

            添加ppa,是因為你所用的ubuntu版本的更新源中可能并沒有你想要的gcc/g++版本。

            安裝新版gcc/g++

            sudo apt-get install gcc-4.8 sudo apt-get install g++-4.8 

            可以到/usr/bin/gcc查看新安裝的gcc,g++

            配置系統gcc/g++

            使用update-alternatives,統一更新gcc/g++

            sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.6 60 --slave /usr/bin/g++ g++ /usr/bin/g++-4.6 sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.8 80 --slave /usr/bin/g++ g++ /usr/bin/g++-4.8 sudo update-alternatives --config gcc 

            數字優先級(如60,80)高的會被系統選擇為默認的編譯器,也可以執行第三條命令就是來手動配置系統的gcc,此處按照提示,選擇4.8版本的即可。

            轉載:http://www.chongh.wiki/blog/2016/05/25/lib-compile-link/

            久久精品无码一区二区无码| AV狠狠色丁香婷婷综合久久 | 久久久亚洲欧洲日产国码是AV| 婷婷久久综合九色综合98| 久久精品国产日本波多野结衣| 久久精品国产第一区二区| 久久精品视频网| 91精品国产91久久久久福利| 久久婷婷五月综合色高清| 亚洲愉拍99热成人精品热久久| 精品一二三区久久aaa片| 国产亚洲精品久久久久秋霞| 亚洲国产另类久久久精品| 色综合久久中文字幕无码| 久久99精品久久久久子伦| 精品免费tv久久久久久久| 品成人欧美大片久久国产欧美...| 狠狠色综合久久久久尤物| 久久国产精品一区| 国产精品久久新婚兰兰| 久久久女人与动物群交毛片| 亚洲国产精品久久久久婷婷软件 | 久久精品国产亚洲AV蜜臀色欲| 久久久久久精品免费看SSS| 蜜臀久久99精品久久久久久小说 | 久久久99精品成人片中文字幕| 久久亚洲av无码精品浪潮| 久久人妻少妇嫩草AV蜜桃| AV狠狠色丁香婷婷综合久久| 99久久国产主播综合精品| 日批日出水久久亚洲精品tv| 亚洲va国产va天堂va久久| 国产精品久久毛片完整版| 欧美午夜精品久久久久久浪潮| 亚洲中文字幕无码久久精品1| 久久精品国产影库免费看| 伊人久久国产免费观看视频| 99久久99这里只有免费的精品| 久久无码人妻精品一区二区三区| 欧美大香线蕉线伊人久久| 久久久久久无码国产精品中文字幕|