在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ C++/ linux環(huán)境下編譯C++ 程序
C++用戶定義異常
C++ this指針
C++存儲類
C++函數(shù)
C++交換變量值
C++ continue語句
C++注釋
C++函數(shù)遞歸
C++ goto語句
C++函數(shù)-通過值調用和引用調用
C++重載
C++語言歷史
C++反轉數(shù)字
C++ try/catch語句
C++是什么?
C++變量
C++ break語句
C++運算符
C++第一個程序
C++繼承
C++虛函數(shù)
C++將十進制轉換為二進制
C++矩陣乘法
C++對象和類
C++基礎輸入輸出(cin,cout,endl)
C++文件和流
C++求素數(shù)
C++ if/else語句
C++友元函數(shù)
C++命名空間
C++面向對象概念
C++階乘
C++關鍵字
C++重載
C++聚合
C++結構體
C++的特點(特性)
C++打印字母表三角
C++ switch語句
C++多態(tài)
C++ do-while循環(huán)
C++字符串
C++ static關鍵字
C++錯誤處理
C++ for循環(huán)
C語言與C++的區(qū)別
C++ while循環(huán)
C++開發(fā)環(huán)境的安裝
linux環(huán)境下編譯C++ 程序
C++枚舉
C++指針
C++斐波納契數(shù)列
C++阿姆斯壯數(shù)字
C++接口
C++教程
C++數(shù)組
C++數(shù)據(jù)抽象
C++回文程序實例
C++打印數(shù)字三角
C++將數(shù)組傳遞到函數(shù)
C++多維數(shù)組
C++將數(shù)字轉換字符

linux環(huán)境下編譯C++ 程序

GCC(GNU Compiler Collection)是Linux下最主要的編譯工具,GCC不僅功能非常強大,結構也異常靈活。它可以通過不同的前端模塊來支持各種語言,如:Java、Fortran、Pascal、Modula-3和Ada。

安裝Gcc和g++:

yum -y install gcc automake autoconf libtool make

安裝g++:

yum install gcc gcc-c++

g++是GCC中的一個工具,專門來編譯C++語言的。
GCC的參數(shù)有:( 也是分步實現(xiàn))

  • -E 讓GCC在預處理結束后停止編譯。
    g++ -E hello.cpp  -o  hello.i
    
  • -chello.i編譯成目標代碼
    g++  -c  hello.i  -o  hello.o
    
    將目標文件連接成可執(zhí)行文件
    g++ hell.o   -o   hello
    
    可以一步實現(xiàn)
    g++  hello.cpp  -o  hello
    

假如有兩個以上源文件應該一下編譯

一步就實現(xiàn):

g++   foo1.cpp   foo2.cpp   -o   foo

也可以分步實現(xiàn):

g++   -c   foo1.cpp  -o   foo1.o
g++   -c    foo2.cpp  -o   foo2.o
g++   foo1.o  foo2.o    -o    foo

GCC一些常用選項

1、產(chǎn)生警告信息的選項大多數(shù)以-W開頭 其中有-Wall

g++  -Wall  hello.cpp   -o   hello

2、將所有的警告當成錯誤的選項-Werror

g++ -Werror  hello.cpp  -o  hello

3、尋找頭文件選項

  • -I (linux默認路徑:頭文件在/usr/include/下),不在這個路徑下就要用-I指定。
    gcc  foo.cpp  -I/home/include   -o  foo
    
    4、 庫依賴選項
  • -L (linux默認路徑:庫文件在/usr/lib/下),不在這個路徑下就要用-L指定。
    g++  foo.cpp  -L/home/lib  -lfoo  -o   foo
    

庫就是將源文件編譯之后生成的目標文件的集合。庫命名以lib開頭。庫有靜態(tài)庫(通常以.a結尾)和動態(tài)庫(通常以.so結尾)默認情況下,g++以動態(tài)庫形式連接。如果要靜態(tài)庫連接則要用-static指定(g++ foo.cpp -L/home/lib -static -lfoo -o foo)

單個源文件生成可執(zhí)行程序

下面是一個保存在文件 helloworld.cpp 中一個簡單的 C++ 程序的代碼: 單個源文件生成可執(zhí)行程序。

/* helloworld.cpp */
#include <iostream>
int main(int argc,char *argv[])
{
    std::cout << "hello, world" << std::endl;
    return(0);
}

程序使用定義在頭文件 iostream 中的 cout,向標準輸出寫入一個簡單的字符串。該代碼可用以下命令編譯為可執(zhí)行文件:

[root@localhost cpp]# g++ helloworld.cpp
[root@localhost cpp]# ll
total 16
-rwxr-xr-x. 1 root   root   9136 Mar  8 03:31 a.out
-rw-rw-r--. 1 yiibai yiibai  138 Mar  8 03:24 helloworld.cpp
[root@localhost cpp]#

編譯器 g++ 通過檢查命令行中指定的文件的后綴名可識別其為 C++ 源代碼文件。
編譯器默認的動作: 編譯源代碼文件生成對象文件(object file),鏈接對象文件和 libstd c++ 庫中的函數(shù)得到可執(zhí)行程序。然后刪除對象文件。由于命令行中未指定可執(zhí)行程序的文件名,編譯器采用默認的a.out。程序可以這樣來運行:

[yiibai@localhost cpp]$ ./a.out
hello, world
[yiibai@localhost cpp]$

更普遍的做法是通過 -o 選項指定可執(zhí)行程序的文件名。下面的命令將產(chǎn)生名為 helloworld 的可執(zhí)行文件:

[yiibai@localhost cpp]$  g++ helloworld.cpp -o helloworld
[yiibai@localhost cpp]$ ll
total 28
-rwxr-xr-x. 1 root   root   9136 Mar  8 03:31 a.out
-rwxrwxr-x. 1 yiibai yiibai 9136 Mar  8 03:32 helloworld
-rw-rw-r--. 1 yiibai yiibai  138 Mar  8 03:24 helloworld.cpp
[yiibai@localhost cpp]$

在命令行中輸入程序名可使之運行:

[yiibai@localhost cpp]$  ./helloworld
hello, world
[yiibai@localhost cpp]$

程序 g++ 是將 gcc 默認語言設為 C++ 的一個特殊的版本,鏈接時它自動使用 C++ 標準庫而不用 C 標準庫。通過遵循源碼的命名規(guī)范并指定對應庫的名字,用 gcc 來編譯鏈接 C++ 程序是可行的,如下例所示:

[yiibai@localhost cpp]$ gcc helloworld.cpp -lstdc++ -o helloworld

選項 -l (ell)通過添加前綴 lib 和后綴 .a 將跟隨它的名字變換為庫的名字libstdc++.a。而后它在標準庫路徑中查找該庫。gcc 的編譯過程和輸出文件與 g++ 是完全相同的。

在大多數(shù)系統(tǒng)中,GCC 安裝時會安裝一名為 c++ 的程序。如果被安裝,它和 g++ 是等同,如下例所示,用法也一致:

[yiibai@localhost cpp]$ c++ helloworld.cpp -o helloworld

多個源文件生成可執(zhí)行程序

如果多于一個的源碼文件在 g++ 命令中指定,它們都將被編譯并被鏈接成一個單一的可執(zhí)行文件。下面是一個名為 speak.h 的頭文件;它包含一個僅含有一個函數(shù)的類的定義:

/* speak.h */
#include <iostream>
class Speak
{
    public:
        void sayHello(const char *);
};

下面列出的是文件 speak.cpp 的內容:包含 sayHello()函數(shù)的函數(shù)體:

/* speak.cpp */
#include "speak.h"
void Speak::sayHello(const char *str)
{
    std::cout << "Hello " << str << "\n";
}

文件hellospeak.cpp內是一個使用 Speak 類的程序:

/* hellospeak.cpp */
#include "speak.h"
int main(int argc,char *argv[])
{
    Speak speak;
    speak.sayHello("world");
    return(0);
}

下面這條命令將上述兩個源碼文件編譯鏈接成一個單一的可執(zhí)行程序:

$ g++ hellospeak.cpp speak.cpp -o hellospeak

提示: 這里說一下為什么在命令中沒有提到“speak.h“文件(原因是:在“speak.cpp“中包含有”#include"speak.h““這句代碼,它的意思是搜索系統(tǒng)頭文件目錄之前將先在當前目錄中搜索文件“speak.h“。而”speak.h“正在該目錄中,不用再在命令中指定了)。

源文件生成對象文件

選項 -c 用來告訴編譯器編譯源代碼但不要執(zhí)行鏈接,輸出結果為對象文件。文件默認名與源碼文件名相同,只是將其后綴變?yōu)?code>.o。例如,下面的命令將編譯源碼文件 hellospeak.cpp并生成對象文件 hellospeak.o

$ g++ -c hellospeak.cpp

命令 g++ 也能識別 .o 文件并將其作為輸入文件傳遞給鏈接器。下列命令將編譯源碼文件為對象文件并將其鏈接成單一的可執(zhí)行程序:

$ g++ -c hellospeak.cpp 
$ g++ -c speak.cpp 
$ g++ hellospeak.o speak.o -o hellospeak

選項 -o 不僅僅能用來命名可執(zhí)行文件。它也用來命名編譯器輸出的其他文件。例如:除了中間的對象文件有不同的名字外,下列命令生將生成和上面完全相同的可執(zhí)行文件:

$ g++ -c hellospeak.cpp -o hspk1.o 
$ g++ -c speak.cpp -o hspk2.o 
$ g++ hspk1.o hspk2.o -o hellospeak

編譯預處理

選項 -E 使 g++ 將源代碼用編譯預處理器處理后不再執(zhí)行其他動作。下面的命令預處理源碼文件 helloworld.cpp 并將結果顯示在標準輸出中:

$ g++ -E helloworld.cpp

本文前面所列出的 helloworld.cpp 的源代碼,僅僅有六行,而且該程序除了顯示一行文字外什么都不做,但是,預處理后的版本將超過 1200 行。這主要是因為頭文件 iostream 被包含進來,而且它又包含了其他的頭文件,除此之外,還有若干個處理輸入和輸出的類的定義。
預處理過的文件的 GCC 后綴為.ii,它可以通過-o 選項來生成,例如:

$ gcc -E helloworld.cpp -o helloworld.ii

生成匯編代碼

選項 -S指示編譯器將程序編譯成匯編語言,輸出匯編語言代碼而后結束。下面的命令將由 C++ 源碼文件生成匯編語言文件 helloworld.s

$ g++ -S helloworld.cpp

生成的匯編語言依賴于編譯器的目標平臺。

創(chuàng)建靜態(tài)庫

靜態(tài)庫是編譯器生成的一系列對象文件的集合。鏈接一個程序時用庫中的對象文件還是目錄中的對象文件都是一樣的。庫中的成員包括普通函數(shù),類定義,類的對象實例等等。靜態(tài)庫的另一個名字叫歸檔文件(archive),管理這種歸檔文件的工具叫 ar 。
在下面的例子中,我們先創(chuàng)建兩個對象模塊,然后用其生成靜態(tài)庫。
頭文件 say.h包含函數(shù) sayHello()的原型和類 Say 的定義:

/* say.h */
#include <iostream>
void sayhello(void);
class Say {
    private:
        char *string;
    public:
        Say(char *str)
        {
            string = str;
        }
        void sayThis(const char *str)
        {
            std::cout << str << " from a static library\n";
        }
        void sayString(void);
};

下面是文件say.cpp是我們要加入到靜態(tài)庫中的兩個對象文件之一的源碼。它包含 Say 類中 sayString()函數(shù)的定義體;類 Say 的一個實例 librarysay的聲明也包含在內:

/* say.cpp */
#include "say.h"
void Say::sayString()
{
    std::cout << string << "\n";
}

Say librarysay("Library instance of Say");
源碼文件 syshello.cpp 是我們要加入到靜態(tài)庫中的第二個對象文件的源碼。它包含函數(shù) sayhello() 的定義:

/* sayhello.cpp */
#include "say.h"
void sayhello()
{
    std::cout << "hello from a static library\n";
}

下面的命令序列將源碼文件編譯成對象文件,命令 ar 將其存進庫中:

$ g++ -c sayhello.cpp
$ g++ -c say.cpp
$ ar -r libsay.a sayhello.o say.o

程序 ar 配合參數(shù) -r 創(chuàng)建一個新庫 libsay.a 并將命令行中列出的對象文件插入。采用這種方法,如果庫不存在的話,參數(shù) -r 將創(chuàng)建一個新的庫,而如果庫存在的話,將用新的模塊替換原來的模塊。
下面是主程序 saymain.cpp,它調用庫 libsay.a 中的代碼:

/* saymain.cpp */
#include "say.h"
int main(int argc,char *argv[])
{
    extern Say librarysay;
    Say localsay = Say("Local instance of Say");
    sayhello();
    librarysay.sayThis("howdy");
    librarysay.sayString();
    localsay.sayString();
    return(0);
}

該程序可以下面的命令來編譯和鏈接:

$ g++ saymain.cpp libsay.a -o saymain

程序運行時,產(chǎn)生以下輸出:

hello from a static library
howdy from a static library
Library instance of SayLocal instance of Say

參考:http://www.cnblogs.com/ucas/p/5778664.html