• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理
            https://www.cnblogs.com/zjutzz/p/4018816.html

            在C++中,有時候需要在不同文件中使用同一個變量。對于這類變量如果處理不當,很容易出現“multiple definition of... first defined here”的錯誤。

            例如,定義了如下3個文件:global.h, a.cpp, b.cpp

            //global.h: #ifndef _GLOBAL_H_ #define _GLOBAL_H_  const int a=1; int b;  #endif
            //a.cpp #include <iostream> #include <stdlib.h> #include "global.h"  using namespace std;  void test1() {      cout<<"test1"<<endl; }
            //b.cpp #include <iostream> #include <stdlib.h> #include "global.h"  using namespace std;  void test2() {     cout<<"test2"<<endl; }  void main() {   cout<<"hello world"<<endl; }

            執行編譯命令:

            g++ -o main a.cpp b.cpp

            提示錯誤為:

            [chris@zz jojo]g++ -o main a.cpp b.cpp
            /tmp/ccc7OcsO.o:(.bss+0x0): multiple definition of `b'
            /tmp/ccs7q2VA.o:(.bss+0x0):第一次在此定義

            出錯原因:a.cpp和b.cpp先分別被編譯為.o格式的目標文件,兩個目標文件再被鏈接器鏈接起來,這當中a.cpp和b.cpp分別進行了一次include,相當于global.h中的代碼重復出現了一次。因為a是const類型,所以重新定義也沒事;但是b只是普通變量,重復定義顯然不行。

            顯然,一個解決辦法是把b定義為const int類型。或者,定義成static int類型也行。

            還有一種解決方案,就是把global.h變為global.c文件,a.cpp和b.cpp中不再include它,但是編譯的時候把global.c也編譯進去,就可以了:

            g++ -o main global.c  a.cpp b.cpp

            再舉一個class相關的例子。比如有Body和Mouth兩個類,Body的greet方法會調用Mouth的say方法,而main函數中會調用全局變量body的greet方法。為了只是用一個body和一個mouth對象,可以這么寫:

            //body.h #ifndef BODY_H #define BODY_H  #include <mouth.h>  class Body { public:     Body();     ~Body();     void greet(); };  extern Body body;   #endif 
            //body.cpp #include <body.h>  Body::Body(){}  Body::~Body() {}  void Body::greet() {     mouth.say(); } 
            //mouth.h #ifndef MOUTH_H #define MOUTH_H  class Mouth { public:     Mouth();     ~Mouth();     void say(); };  extern Mouth mouth;   #endif 
            //mouth.cpp #include <mouth.h> #include <iostream>  using namespace std;  Mouth::Mouth() {}  Mouth::~Mouth() {}  void Mouth::say() {     cout << "Have a Nice day!" << endl; } 
            //class.cpp #include <body.h> #include <mouth.h>   Body body; Mouth mouth; 
            //main.cpp #include <iostream> #include <body.h> using namespace std;  int main() {     body.greet(); } 

            上面代碼中的include,雖然都是用的尖括號,但因為編譯時可以通過指定include路徑,不會出問題~
            編譯命令:

            g++ -I ./ mouth.cpp body.cpp class.cpp main.cpp -o main

            能夠正常運行。

            久久精品国产亚洲av水果派 | 久久性生大片免费观看性| 久久久青草久久久青草| 国产精品综合久久第一页| 2020久久精品亚洲热综合一本| 国产精品一区二区久久精品涩爱| 国产精品久久久久国产A级| 欧美日韩精品久久久免费观看| 性欧美大战久久久久久久久| 国产三级精品久久| 精品久久久久中文字幕日本| 久久国产福利免费| 久久久91精品国产一区二区三区| 久久人人爽人人人人片av| 国产精品久久久久乳精品爆| 色诱久久久久综合网ywww| 久久综合五月丁香久久激情| 久久久久四虎国产精品| 精品久久久久香蕉网| 精品久久久无码21p发布| 亚洲伊人久久成综合人影院 | 久久精品无码专区免费| 久久久亚洲欧洲日产国码二区| 亚洲伊人久久综合影院| 久久国产成人| 欧美大战日韩91综合一区婷婷久久青草| 国内精品伊人久久久久AV影院| 久久国产色av免费看| 久久久久波多野结衣高潮| 日韩中文久久| 久久精品免费全国观看国产| 久久精品视频91| 青春久久| 一本色综合久久| 国产精品久久久久久久久久影院| 久久中文字幕视频、最近更新| 久久AAAA片一区二区| 青青草原综合久久大伊人导航| 久久国产成人午夜aⅴ影院| 日日狠狠久久偷偷色综合0| 久久久久香蕉视频|