2014-09-27 42 views
1

我在工作中有一臺電腦,關於這一點我沒有須藤權限(它是由系統管理員進行管理),我只有在/home/my_user_name/寫權限我們用科學的Linux發行6.3 gcc版本4.4 0.7。我想編譯自己的gcc 4.9.1,安裝它,例如/home/my_user_name/local/gcc/,並且能夠與舊的gcc 4.4.7同時使用它。安裝GCC在家裏

據我所知,默認情況下,g ++會在查看用戶指定的目錄之前,檢查/usr//usr/local/的標題和庫。此外,可執行文件在運行時檢查共享對象的默認路徑。 我想要什麼,是GCC-4.4.7使用自己的頭文件,庫,鏈接器等,併爲GCC-4.9.1使用它自己的一套,沒有/usr/和看到這樣的舊版本的那些東西。對於可執行文件,可以自動知道在哪裏查找編譯的庫。我也希望兩個編譯器能夠同時使用。我也希望這適用於包含在gcc中的gfortran和其他編譯器。

可以這樣做嗎?設置這個最好的方法是什麼?我需要知道或擔心什麼?

感謝

回答

1

可以這樣做?設置這個最好的方法是什麼?我需要 知道或擔心什麼?

是的,這可以做到。事實上,在一臺機器上安裝多個版本的GCC是非常有用的。你可以在你的路徑/home/my_user_name/local/gcc/下載並安裝gcc4.9。您可以參考以下有關如何使用源文件安裝GCC4.9的鏈接。

How do I compile and run GCC 4.9.0?

一旦你與步驟完成後,你應該能夠通過提供完整的路徑使用GCC4.9.1。最好的方法是編寫一個makefile並使用它來避免長類型。

如果一切順利您的GCC4.9安裝,下面的命令應該給予這樣的輸出:

$/home/mantosh/gcc-4.9.1/bin/gcc -v 
Using built-in specs. 
COLLECT_GCC=/home/mantosh/gcc-4.9.1/bin/gcc 
COLLECT_LTO_WRAPPER=/home/mantosh/gcc-4.9.1/libexec/gcc/x86_64-unknown-linux-gnu/4.9.1/lto-wrapper 
Target: x86_64-unknown-linux-gnu 
Configured with: /home/mantosh/objdir/../gcc-4.9.1/configure --prefix=/home/mantosh/gcc-4.9.1 --disable-multilib 
Thread model: posix 
gcc version 4.9.1 (GCC) 


$ gcc -v 
Using built-in specs. 
COLLECT_GCC=gcc 
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/4.8/lto-wrapper 
Target: x86_64-linux-gnu 
Configured with: ../src/configure -v --with-pkgversion='Ubuntu 4.8.1-2ubuntu1~12.04' --with-bugurl=file:///usr/share/doc/gcc-4.8/README.Bugs --enable-languages=c,c++,java,go,d,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.8 --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.8 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --with-system-zlib --disable-browser-plugin --enable-java-awt=gtk --enable-gtk-cairo --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-4.8-amd64/jre --enable-java-home --with-jvm-root-dir=/usr/lib/jvm/java-1.5.0-gcj-4.8-amd64 --with-jvm-jar-dir=/usr/lib/jvm-exports/java-1.5.0-gcj-4.8-amd64 --with-arch-directory=amd64 --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --enable-objc-gc --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64 --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu 
Thread model: posix 
gcc version 4.8.1 (Ubuntu 4.8.1-2ubuntu1~12.04) 

所以從上面我們可以看到,GCC4.8是我的默認編譯器和GCC4.9.1是安裝了其他編譯​​器。第一個是默認編譯的gcc(在我的例子中是gcc4.8),第二個是gcc4.9.1。因爲我們正在命令行上提供完整的路徑。

$g++ test.cpp 
$/home/mantosh/gcc4.9.1/bin/g++ test.cpp 
+0

那麼,你是說我並不需要指定,也不在LIBRARY_PATH或LD_LIBRARY_PATH新庫的路徑,從GCC 4.9 C_INCLUDE_PATH和CPLUS_INCLUDE_PATH新的頭?可執行文件將如何知道在哪裏可以找到新庫?或者有一個隱式的rpath設置爲gcc庫鏈接? – SU3 2014-09-27 05:30:46

+0

是的,只要給出完整的路徑,一切都將由新的編譯器選擇。 – 2014-09-27 06:02:07

+0

你或許應該以'... /配置前綴= $ HOME /柔和/'和其他可能的選擇,也許'--program後綴= -mine'編譯GCC 4.9.1(或更新版本).. – 2014-09-27 06:30:30